summaryrefslogtreecommitdiff
path: root/app/services/members/approve_access_request_service.rb
diff options
context:
space:
mode:
Diffstat (limited to 'app/services/members/approve_access_request_service.rb')
-rw-r--r--app/services/members/approve_access_request_service.rb42
1 files changed, 8 insertions, 34 deletions
diff --git a/app/services/members/approve_access_request_service.rb b/app/services/members/approve_access_request_service.rb
index 2a2bb0cae5b..19431ac76dc 100644
--- a/app/services/members/approve_access_request_service.rb
+++ b/app/services/members/approve_access_request_service.rb
@@ -1,51 +1,25 @@
module Members
- class ApproveAccessRequestService < BaseService
- include MembersHelper
-
- attr_accessor :source
-
- # source - The source object that respond to `#requesters` (i.g. project or group)
- # current_user - The user that performs the access request approval
- # params - A hash of parameters
- # :user_id - User ID used to retrieve the access requester
- # :id - Member ID used to retrieve the access requester
- # :access_level - Optional access level set when the request is accepted
- def initialize(source, current_user, params = {})
- @source = source
- @current_user = current_user
- @params = params.slice(:user_id, :id, :access_level)
- end
-
+ class ApproveAccessRequestService < Members::BaseService
# opts - A hash of options
- # :force - Bypass permission check: current_user can be nil in that case
- def execute(opts = {})
- condition = params[:user_id] ? { user_id: params[:user_id] } : { id: params[:id] }
- access_requester = source.requesters.find_by!(condition)
-
- raise Gitlab::Access::AccessDeniedError unless can_update_access_requester?(access_requester, opts)
+ # :ldap - The call is from a LDAP sync: current_user can be nil in that case
+ def execute(access_requester, opts = {})
+ raise Gitlab::Access::AccessDeniedError unless can_update_access_requester?(access_requester, opts[:ldap])
access_requester.access_level = params[:access_level] if params[:access_level]
access_requester.accept_request
+ after_execute(member: access_requester, **opts)
+
access_requester
end
private
- def can_update_access_requester?(access_requester, opts = {})
+ def can_update_access_requester?(access_requester, ldap)
access_requester && (
- opts[:force] ||
+ ldap ||
can?(current_user, update_member_permission(access_requester), access_requester)
)
end
-
- def update_member_permission(member)
- case member
- when GroupMember
- :update_group_member
- when ProjectMember
- :update_project_member
- end
- end
end
end