bf41063679
Move it to Members::ApproveAccessRequestService. Also, note that there was a double audit event log for access request destruction. Signed-off-by: Rémy Coutable <remy@rymai.me>
18 lines
443 B
Ruby
18 lines
443 B
Ruby
module Members
|
|
class RequestAccessService < Members::BaseService
|
|
def execute
|
|
raise Gitlab::Access::AccessDeniedError unless can_request_access?(source)
|
|
|
|
source.members.create(
|
|
access_level: Gitlab::Access::DEVELOPER,
|
|
user: current_user,
|
|
requested_at: Time.now.utc)
|
|
end
|
|
|
|
private
|
|
|
|
def can_request_access?(source)
|
|
source && can?(current_user, :request_access, source)
|
|
end
|
|
end
|
|
end
|