Commit 847ca9d5 authored by Stan Hu's avatar Stan Hu

Resolve conflicts in app/services/members/destroy_service.rb

parent 7548c9aa
module Members module Members
class DestroyService < Members::BaseService class DestroyService < Members::BaseService
<<<<<<< HEAD
prepend EE::Members::DestroyService prepend EE::Members::DestroyService
def execute(member, skip_authorization: false) def execute(member, skip_authorization: false)
...@@ -12,17 +11,6 @@ module Members ...@@ -12,17 +11,6 @@ module Members
unassign_issues_and_merge_requests(member) unless member.invite? unassign_issues_and_merge_requests(member) unless member.invite?
member.notification_setting&.destroy member.notification_setting&.destroy
=======
def execute(member, skip_authorization: false)
raise Gitlab::Access::AccessDeniedError unless skip_authorization || can_destroy_member?(member)
return member if member.is_a?(GroupMember) && member.source.last_owner?(member.user)
Member.transaction do
unassign_issues_and_merge_requests(member) unless member.invite?
member.notification_setting&.destroy
>>>>>>> upstream/master
member.destroy member.destroy
end end
...@@ -49,43 +37,7 @@ module Members ...@@ -49,43 +37,7 @@ module Members
:destroy_project_member :destroy_project_member
else else
raise "Unknown member type: #{member}!" raise "Unknown member type: #{member}!"
<<<<<<< HEAD
end
end
def unassign_issues_and_merge_requests(member)
if member.is_a?(GroupMember)
issues = Issue.unscoped.select(1)
.joins(:project)
.where('issues.id = issue_assignees.issue_id AND projects.namespace_id = ?', member.source_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
MergeRequestsFinder.new(current_user, group_id: member.source_id, assignee_id: member.user_id)
.execute
.update_all(assignee_id: nil)
else
project = member.source
# 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
project.merge_requests.opened.assigned_to(member.user).update_all(assignee_id: nil)
=======
>>>>>>> upstream/master
end end
member.user.invalidate_cache_counts
end end
def unassign_issues_and_merge_requests(member) def unassign_issues_and_merge_requests(member)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment