debian-mirror-gitlab/app/services/merge_requests/create_service.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

72 lines
2.3 KiB
Ruby
Raw Normal View History

2018-11-18 11:00:15 +05:30
# frozen_string_literal: true
2014-09-02 18:07:02 +05:30
module MergeRequests
class CreateService < MergeRequests::BaseService
def execute
2018-03-17 18:26:18 +05:30
set_projects!
2015-09-11 14:41:01 +05:30
2016-09-13 17:45:13 +05:30
merge_request = MergeRequest.new
2017-09-10 17:25:29 +05:30
merge_request.target_project = @project
2018-03-17 18:26:18 +05:30
merge_request.source_project = @source_project
2017-09-10 17:25:29 +05:30
merge_request.source_branch = params[:source_branch]
2014-09-02 18:07:02 +05:30
2016-09-13 17:45:13 +05:30
create(merge_request)
end
2014-09-02 18:07:02 +05:30
2016-09-13 17:45:13 +05:30
def after_create(issuable)
2023-01-13 00:05:48 +05:30
current_user_id = current_user.id
issuable.run_after_commit do
# Add new items to MergeRequests::AfterCreateService if they can
# be performed in Sidekiq
NewMergeRequestWorker.perform_async(issuable.id, current_user_id)
end
2021-04-29 21:17:54 +05:30
2023-01-13 00:05:48 +05:30
issuable.mark_as_preparing
2020-04-08 14:13:33 +05:30
2018-03-17 18:26:18 +05:30
super
end
# expose issuable create method so it can be called from email
# handler CreateMergeRequestHandler
2022-07-16 23:28:13 +05:30
public :create
2017-09-10 17:25:29 +05:30
private
2022-05-07 20:08:51 +05:30
def before_create(merge_request)
# If the fetching of the source branch occurs in an ActiveRecord
# callback (e.g. after_create), a database transaction will be
# open while the Gitaly RPC waits. To avoid an idle in transaction
# timeout, we do this before we attempt to save the merge request.
2023-01-13 00:05:48 +05:30
if Feature.enabled?(:async_merge_request_diff_creation, current_user)
merge_request.skip_ensure_merge_request_diff = true
else
merge_request.eager_fetch_ref!
end
2022-05-07 20:08:51 +05:30
end
2018-03-17 18:26:18 +05:30
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)
2018-05-09 12:01:36 +05:30
unless can?(current_user, :create_merge_request_from, @source_project) &&
can?(current_user, :create_merge_request_in, @project)
2018-03-17 18:26:18 +05:30
raise Gitlab::Access::AccessDeniedError
end
end
2014-09-02 18:07:02 +05:30
end
end
2019-12-04 20:38:33 +05:30
2023-01-13 00:05:48 +05:30
MergeRequests::CreateService.prepend_mod_with('MergeRequests::CreateService')