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

61 lines
1.9 KiB
Ruby
Raw Normal View History

2014-09-02 18:07:02 +05:30
require_relative 'base_service'
require_relative 'reopen_service'
require_relative 'close_service'
module MergeRequests
class UpdateService < MergeRequests::BaseService
def execute(merge_request)
# We dont allow change of source/target projects
# after merge request was created
params.except!(:source_project_id)
params.except!(:target_project_id)
state = params[:state_event]
case state
when 'reopen'
MergeRequests::ReopenService.new(project, current_user, {}).execute(merge_request)
when 'close'
MergeRequests::CloseService.new(project, current_user, {}).execute(merge_request)
2015-04-26 12:48:37 +05:30
when 'task_check'
merge_request.update_nth_task(params[:task_num].to_i, true)
when 'task_uncheck'
merge_request.update_nth_task(params[:task_num].to_i, false)
2014-09-02 18:07:02 +05:30
end
2015-04-26 12:48:37 +05:30
params[:assignee_id] = "" if params[:assignee_id] == IssuableFinder::NONE
params[:milestone_id] = "" if params[:milestone_id] == IssuableFinder::NONE
old_labels = merge_request.labels.to_a
if params.present? && merge_request.update_attributes(
params.except(:state_event, :task_num)
)
2014-09-02 18:07:02 +05:30
merge_request.reset_events_cache
2015-04-26 12:48:37 +05:30
if merge_request.labels != old_labels
create_labels_note(
merge_request,
merge_request.labels - old_labels,
old_labels - merge_request.labels
)
end
2014-09-02 18:07:02 +05:30
if merge_request.previous_changes.include?('milestone_id')
create_milestone_note(merge_request)
end
if merge_request.previous_changes.include?('assignee_id')
create_assignee_note(merge_request)
2015-04-26 12:48:37 +05:30
notification_service.reassigned_merge_request(merge_request, current_user)
2014-09-02 18:07:02 +05:30
end
merge_request.notice_added_references(merge_request.project, current_user)
2015-04-26 12:48:37 +05:30
execute_hooks(merge_request, 'update')
2014-09-02 18:07:02 +05:30
end
merge_request
end
end
end