Class: PersonalAccessTokens::CreateService
- Inherits:
-
BaseService
- Object
- BaseService
- PersonalAccessTokens::CreateService
- Defined in:
- app/services/personal_access_tokens/create_service.rb
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 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.
5 6 7 8 9 10 11 12 |
# File 'app/services/personal_access_tokens/create_service.rb', line 5 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
14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 |
# File 'app/services/personal_access_tokens/create_service.rb', line 14 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) notification_service.access_token_created(target_user, token.name) 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 |