2021-04-29 21:17:54 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module MergeRequests
|
|
|
|
class HandleAssigneesChangeService < MergeRequests::BaseService
|
|
|
|
def async_execute(merge_request, old_assignees, options = {})
|
2021-06-08 01:23:25 +05:30
|
|
|
MergeRequests::HandleAssigneesChangeWorker
|
|
|
|
.perform_async(
|
|
|
|
merge_request.id,
|
|
|
|
current_user.id,
|
|
|
|
old_assignees.map(&:id),
|
2021-09-04 01:27:46 +05:30
|
|
|
options.stringify_keys # see: https://gitlab.com/gitlab-com/gl-infra/scalability/-/issues/1090
|
2021-06-08 01:23:25 +05:30
|
|
|
)
|
2021-04-29 21:17:54 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
def execute(merge_request, old_assignees, options = {})
|
|
|
|
create_assignee_note(merge_request, old_assignees)
|
|
|
|
notification_service.async.reassigned_merge_request(merge_request, current_user, old_assignees.to_a)
|
|
|
|
todo_service.reassigned_assignable(merge_request, current_user, old_assignees)
|
|
|
|
|
|
|
|
new_assignees = merge_request.assignees - old_assignees
|
|
|
|
merge_request_activity_counter.track_users_assigned_to_mr(users: new_assignees)
|
|
|
|
merge_request_activity_counter.track_assignees_changed_action(user: current_user)
|
|
|
|
|
|
|
|
execute_assignees_hooks(merge_request, old_assignees) if options[:execute_hooks]
|
2022-01-26 12:08:38 +05:30
|
|
|
|
2022-03-02 08:16:31 +05:30
|
|
|
unless new_assignees.include?(current_user)
|
2022-05-07 20:08:51 +05:30
|
|
|
remove_attention_requested(merge_request)
|
2022-03-02 08:16:31 +05:30
|
|
|
end
|
2021-04-29 21:17:54 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def execute_assignees_hooks(merge_request, old_assignees)
|
|
|
|
execute_hooks(
|
|
|
|
merge_request,
|
|
|
|
'update',
|
|
|
|
old_associations: { assignees: old_assignees }
|
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2021-06-08 01:23:25 +05:30
|
|
|
MergeRequests::HandleAssigneesChangeService.prepend_mod_with('MergeRequests::HandleAssigneesChangeService')
|