Class: PersonalAccessTokens::CreateService
- Inherits:
-
BaseService
- Object
- BaseService
- PersonalAccessTokens::CreateService
- Includes:
- Gitlab::InternalEventsTracking
- Defined in:
- app/services/personal_access_tokens/create_service.rb
Constant Summary
Constants inherited from BaseService
BaseService::UnauthorizedError
Instance Attribute Summary
Attributes inherited from BaseService
#current_user, #params, #project
Instance Method Summary collapse
- #execute ⇒ Object
-
#initialize(current_user:, target_user:, organization_id:, params: {}, concatenate_errors: true) ⇒ CreateService
constructor
A new instance of CreateService.
Methods included from Gitlab::InternalEventsTracking
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
#initialize(current_user:, target_user:, organization_id:, params: {}, concatenate_errors: true) ⇒ CreateService
Returns a new instance of CreateService.
7 8 9 10 11 12 13 14 |
# File 'app/services/personal_access_tokens/create_service.rb', line 7 def initialize(current_user:, target_user:, organization_id:, params: {}, concatenate_errors: true) @current_user = current_user @target_user = target_user @params = params.dup @ip_address = @params.delete(:ip_address) @concatenate_errors = concatenate_errors @organization_id = organization_id end |
Instance Method Details
#execute ⇒ Object
16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 |
# File 'app/services/personal_access_tokens/create_service.rb', line 16 def execute return ServiceResponse.error(message: 'Not permitted to create') unless creation_permitted? token = target_user.personal_access_tokens.create(personal_access_token_params) if token.persisted? log_event(token) track_event(token) token.run_after_commit_or_now do NotificationService.new.access_token_created(token.user, token.name) end ServiceResponse.success(payload: { personal_access_token: token }) else = token.errors. = .to_sentence if @concatenate_errors ServiceResponse.error(message: , payload: { personal_access_token: token }) end end |