Class: MergeRequests::HandleAssigneesChangeService
- Inherits:
-
BaseService
- Object
- BaseContainerService
- IssuableBaseService
- BaseService
- MergeRequests::HandleAssigneesChangeService
- Defined in:
- app/services/merge_requests/handle_assignees_change_service.rb
Instance Attribute Summary
Attributes inherited from BaseContainerService
#container, #current_user, #group, #params, #project
Instance Method Summary collapse
- #async_execute(merge_request, old_assignees, options = {}) ⇒ Object
- #execute(merge_request, old_assignees, options = {}) ⇒ Object
Methods inherited from BaseService
#cancel_review_app_jobs!, #cleanup_environments, #create_note, #deactivate_pages_deployments, #execute_external_hooks, #execute_group_mention_hooks, #execute_hooks, #handle_assignees_change, #handle_changes, #handle_reviewers_change, #hook_data, #initialize, #inspect, #merge_request_activity_counter, #source_project, #target_project
Methods included from Gitlab::Utils::Override
#extended, extensions, #included, #method_added, #override, #prepended, #queue_verification, verify!
Methods included from ErrorLogger
Methods included from AssignsMergeParams
#assign_allowed_merge_params, included
Methods inherited from BaseContainerService
#group_container?, #initialize, #namespace_container?, #project_container?, #project_group, #root_ancestor
Methods included from BaseServiceUtility
#deny_visibility_level, #event_service, #log_error, #log_info, #notification_service, #system_hook_service, #todo_service, #visibility_level
Methods included from Gitlab::Allowable
Constructor Details
This class inherits a constructor from MergeRequests::BaseService
Instance Method Details
#async_execute(merge_request, old_assignees, options = {}) ⇒ Object
5 6 7 8 9 10 11 12 13 |
# File 'app/services/merge_requests/handle_assignees_change_service.rb', line 5 def async_execute(merge_request, old_assignees, = {}) MergeRequests::HandleAssigneesChangeWorker .perform_async( merge_request.id, current_user.id, old_assignees.map(&:id), .stringify_keys # see: https://gitlab.com/gitlab-com/gl-infra/scalability/-/issues/1090 ) end |
#execute(merge_request, old_assignees, options = {}) ⇒ Object
15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 |
# File 'app/services/merge_requests/handle_assignees_change_service.rb', line 15 def execute(merge_request, old_assignees, = {}) create_assignee_note(merge_request, old_assignees) notification_service.async.reassigned_merge_request(merge_request, current_user, old_assignees.to_a) Gitlab::ResourceEvents::AssignmentEventRecorder.new(parent: merge_request, old_assignees: old_assignees).record 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) if current_user.merge_request_dashboard_enabled? invalidate_cache_counts(merge_request, users: merge_request.assignees) end invalidate_cache_counts(merge_request, users: old_assignees) execute_assignees_hooks(merge_request, old_assignees) if ['execute_hooks'] end |