2012-09-05 01:01:20 -04:00
|
|
|
# Includes methods for handling Git Push events
|
|
|
|
#
|
|
|
|
# Triggered by PostReceive job
|
2012-08-21 14:26:56 -04:00
|
|
|
module PushObserver
|
2012-06-07 08:44:57 -04:00
|
|
|
def observe_push(oldrev, newrev, ref, user)
|
|
|
|
data = post_receive_data(oldrev, newrev, ref, user)
|
|
|
|
|
|
|
|
Event.create(
|
2012-08-10 18:07:50 -04:00
|
|
|
project: self,
|
|
|
|
action: Event::Pushed,
|
|
|
|
data: data,
|
|
|
|
author_id: data[:user_id]
|
2012-06-07 08:44:57 -04:00
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
def update_merge_requests(oldrev, newrev, ref, user)
|
|
|
|
return true unless ref =~ /heads/
|
|
|
|
branch_name = ref.gsub("refs/heads/", "")
|
|
|
|
c_ids = self.commits_between(oldrev, newrev).map(&:id)
|
|
|
|
|
|
|
|
# Update code for merge requests
|
|
|
|
mrs = self.merge_requests.opened.find_all_by_branch(branch_name).all
|
|
|
|
mrs.each { |merge_request| merge_request.reload_code; merge_request.mark_as_unchecked }
|
|
|
|
|
|
|
|
# Close merge requests
|
2012-08-10 18:07:50 -04:00
|
|
|
mrs = self.merge_requests.opened.where(target_branch: branch_name).all
|
2012-07-02 04:44:45 -04:00
|
|
|
mrs = mrs.select(&:last_commit).select { |mr| c_ids.include?(mr.last_commit.id) }
|
2012-06-07 08:44:57 -04:00
|
|
|
mrs.each { |merge_request| merge_request.merge!(user.id) }
|
|
|
|
|
|
|
|
true
|
|
|
|
end
|
|
|
|
|
2012-07-15 10:36:06 -04:00
|
|
|
def execute_hooks(oldrev, newrev, ref, user)
|
2012-06-07 08:44:57 -04:00
|
|
|
ref_parts = ref.split('/')
|
|
|
|
|
|
|
|
# Return if this is not a push to a branch (e.g. new commits)
|
|
|
|
return if ref_parts[1] !~ /heads/ || oldrev == "00000000000000000000000000000000"
|
|
|
|
|
|
|
|
data = post_receive_data(oldrev, newrev, ref, user)
|
|
|
|
|
2012-07-15 10:36:06 -04:00
|
|
|
hooks.each { |hook| hook.execute(data) }
|
2012-06-07 08:44:57 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def post_receive_data(oldrev, newrev, ref, user)
|
|
|
|
|
|
|
|
push_commits = commits_between(oldrev, newrev)
|
|
|
|
|
|
|
|
# Total commits count
|
|
|
|
push_commits_count = push_commits.size
|
|
|
|
|
|
|
|
# Get latest 20 commits ASC
|
|
|
|
push_commits_limited = push_commits.last(20)
|
|
|
|
|
|
|
|
# Hash to be passed as post_receive_data
|
|
|
|
data = {
|
|
|
|
before: oldrev,
|
|
|
|
after: newrev,
|
|
|
|
ref: ref,
|
|
|
|
user_id: user.id,
|
|
|
|
user_name: user.name,
|
|
|
|
repository: {
|
|
|
|
name: name,
|
|
|
|
url: web_url,
|
|
|
|
description: description,
|
|
|
|
homepage: web_url,
|
|
|
|
},
|
|
|
|
commits: [],
|
|
|
|
total_commits_count: push_commits_count
|
|
|
|
}
|
|
|
|
|
2012-07-02 04:44:45 -04:00
|
|
|
# For perfomance purposes maximum 20 latest commits
|
2012-06-07 08:44:57 -04:00
|
|
|
# will be passed as post receive hook data.
|
|
|
|
#
|
|
|
|
push_commits_limited.each do |commit|
|
|
|
|
data[:commits] << {
|
|
|
|
id: commit.id,
|
|
|
|
message: commit.safe_message,
|
|
|
|
timestamp: commit.date.xmlschema,
|
2012-07-02 14:51:48 -04:00
|
|
|
url: "#{Gitlab.config.url}/#{code}/commits/#{commit.id}",
|
2012-06-07 08:44:57 -04:00
|
|
|
author: {
|
|
|
|
name: commit.author_name,
|
|
|
|
email: commit.author_email
|
|
|
|
}
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
data
|
|
|
|
end
|
|
|
|
|
2012-09-05 01:01:20 -04:00
|
|
|
# This method will be called after each post receive and only if the provided
|
|
|
|
# user is present in GitLab.
|
2012-06-07 08:44:57 -04:00
|
|
|
#
|
2012-09-05 01:01:20 -04:00
|
|
|
# All callbacks for post receive should be placed here.
|
2012-07-02 04:44:45 -04:00
|
|
|
def trigger_post_receive(oldrev, newrev, ref, user)
|
2012-06-07 08:44:57 -04:00
|
|
|
# Create push event
|
|
|
|
self.observe_push(oldrev, newrev, ref, user)
|
|
|
|
|
2012-07-02 04:44:45 -04:00
|
|
|
# Close merged MR
|
2012-06-07 08:44:57 -04:00
|
|
|
self.update_merge_requests(oldrev, newrev, ref, user)
|
|
|
|
|
|
|
|
# Execute web hooks
|
2012-07-15 10:36:06 -04:00
|
|
|
self.execute_hooks(oldrev, newrev, ref, user)
|
2012-06-07 08:44:57 -04:00
|
|
|
|
|
|
|
# Create satellite
|
|
|
|
self.satellite.create unless self.satellite.exists?
|
2012-09-05 01:01:20 -04:00
|
|
|
|
|
|
|
# Discover the default branch, but only if it hasn't already been set to
|
|
|
|
# something else
|
|
|
|
if default_branch.nil?
|
|
|
|
update_attributes(default_branch: discover_default_branch)
|
|
|
|
end
|
2012-06-07 08:44:57 -04:00
|
|
|
end
|
|
|
|
end
|