75 lines
2.4 KiB
Ruby
75 lines
2.4 KiB
Ruby
module MergeRequests
|
|
class CreateService < MergeRequests::BaseService
|
|
def execute
|
|
set_projects!
|
|
|
|
merge_request = MergeRequest.new
|
|
merge_request.target_project = @project
|
|
merge_request.source_project = @source_project
|
|
merge_request.source_branch = params[:source_branch]
|
|
merge_request.merge_params['force_remove_source_branch'] = params.delete(:force_remove_source_branch)
|
|
|
|
create(merge_request)
|
|
end
|
|
|
|
def before_create(merge_request)
|
|
# current_user (defined in BaseService) is not available within run_after_commit block
|
|
user = current_user
|
|
merge_request.run_after_commit do
|
|
NewMergeRequestWorker.perform_async(merge_request.id, user.id)
|
|
end
|
|
end
|
|
|
|
def after_create(issuable)
|
|
todo_service.new_merge_request(issuable, current_user)
|
|
issuable.cache_merge_request_closes_issues!(current_user)
|
|
update_merge_requests_head_pipeline(issuable)
|
|
|
|
super
|
|
end
|
|
|
|
# expose issuable create method so it can be called from email
|
|
# handler CreateMergeRequestHandler
|
|
def create(merge_request)
|
|
super
|
|
end
|
|
|
|
private
|
|
|
|
def update_merge_requests_head_pipeline(merge_request)
|
|
pipeline = head_pipeline_for(merge_request)
|
|
merge_request.update(head_pipeline_id: pipeline.id) if pipeline
|
|
end
|
|
|
|
def head_pipeline_for(merge_request)
|
|
return unless merge_request.source_project
|
|
|
|
sha = merge_request.source_branch_sha
|
|
return unless sha
|
|
|
|
pipelines = merge_request.source_project.pipelines.where(ref: merge_request.source_branch, sha: sha)
|
|
|
|
pipelines.order(id: :desc).first
|
|
end
|
|
|
|
def set_projects!
|
|
# @project is used to determine whether the user can set the merge request's
|
|
# assignee, milestone and labels. Whether they can depends on their
|
|
# permissions on the target project.
|
|
@source_project = @project
|
|
@project = Project.find(params[:target_project_id]) if params[:target_project_id]
|
|
|
|
# make sure that source/target project ids are not in
|
|
# params so it can't be overridden later when updating attributes
|
|
# from params when applying quick actions
|
|
params.delete(:source_project_id)
|
|
params.delete(:target_project_id)
|
|
|
|
unless can?(current_user, :read_project, @source_project) &&
|
|
can?(current_user, :read_project, @project)
|
|
|
|
raise Gitlab::Access::AccessDeniedError
|
|
end
|
|
end
|
|
end
|
|
end
|