authorized_destroy_service.rb 1.7 KB
Newer Older
1 2 3 4 5 6 7 8 9
module Members
  class AuthorizedDestroyService < BaseService
    attr_accessor :member, :user

    def initialize(member, user = nil)
      @member, @user = member, user
    end

    def execute
10 11
      return false if member.is_a?(GroupMember) && member.source.last_owner?(member.user)

12 13 14 15 16
      Member.transaction do
        unassign_issues_and_merge_requests(member)

        member.destroy
      end
17 18 19 20

      if member.request? && member.user != user
        notification_service.decline_access_request(member)
      end
21 22

      member
23
    end
24 25 26 27 28

    private

    def unassign_issues_and_merge_requests(member)
      if member.is_a?(GroupMember)
29 30 31
        issue_ids = IssuesFinder.new(user, group_id: member.source_id, assignee_id: member.user_id).
          execute.pluck(:id)

32
        IssueAssignee.delete_all(issue_id: issue_ids, user_id: member.user_id)
33

34 35 36 37 38
        MergeRequestsFinder.new(user, group_id: member.source_id, assignee_id: member.user_id).
          execute.
          update_all(assignee_id: nil)
      else
        project = member.source
39

40 41 42 43 44 45 46 47 48
        # SELECT 1 FROM issues WHERE issues.id = issue_assignees.issue_id AND issues.project_id = X
        issues = Issue.unscoped.select(1).
                 where('issues.id = issue_assignees.issue_id').
                 where(project_id: project.id)

        # DELETE FROM issue_assignees WHERE user_id = X AND EXISTS (...)
        IssueAssignee.unscoped.
          where('user_id = :user_id AND EXISTS (:sub)', user_id: member.user_id, sub: issues).
          delete_all
49

50 51
        project.merge_requests.opened.assigned_to(member.user).update_all(assignee_id: nil)
      end
52 53

      member.user.invalidate_cache_counts
54
    end
55 56
  end
end