54 lines
1.4 KiB
Ruby
54 lines
1.4 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Clusters
|
|
module AgentTokens
|
|
class CreateService
|
|
ALLOWED_PARAMS = %i[agent_id description name].freeze
|
|
|
|
attr_reader :agent, :current_user, :params
|
|
|
|
def initialize(agent:, current_user:, params:)
|
|
@agent = agent
|
|
@current_user = current_user
|
|
@params = params
|
|
end
|
|
|
|
def execute
|
|
return error_no_permissions unless current_user.can?(:create_cluster, agent.project)
|
|
|
|
token = ::Clusters::AgentToken.new(filtered_params.merge(agent_id: agent.id, created_by_user: current_user))
|
|
|
|
if token.save
|
|
log_activity_event(token)
|
|
|
|
ServiceResponse.success(payload: { secret: token.token, token: token })
|
|
else
|
|
ServiceResponse.error(message: token.errors.full_messages)
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def error_no_permissions
|
|
ServiceResponse.error(message: s_('ClusterAgent|User has insufficient permissions to create a token for this project'))
|
|
end
|
|
|
|
def filtered_params
|
|
params.slice(*ALLOWED_PARAMS)
|
|
end
|
|
|
|
def log_activity_event(token)
|
|
Clusters::Agents::CreateActivityEventService.new(
|
|
token.agent,
|
|
kind: :token_created,
|
|
level: :info,
|
|
recorded_at: token.created_at,
|
|
user: current_user,
|
|
agent_token: token
|
|
).execute
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
Clusters::AgentTokens::CreateService.prepend_mod
|