debian-mirror-gitlab/app/graphql/mutations/ci/runners_registration_token/reset.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

66 lines
1.7 KiB
Ruby
Raw Normal View History

2021-09-04 01:27:46 +05:30
# frozen_string_literal: true
module Mutations
module Ci
module RunnersRegistrationToken
class Reset < BaseMutation
graphql_name 'RunnersRegistrationTokenReset'
authorize :update_runners_registration_token
2021-10-27 15:23:28 +05:30
ScopeID = ::GraphQL::Types::ID
2021-09-04 01:27:46 +05:30
argument :type, ::Types::Ci::RunnerTypeEnum,
required: true,
description: 'Scope of the object to reset the token for.'
argument :id, ScopeID,
required: false,
description: 'ID of the project or group to reset the token for. Omit if resetting instance runner token.'
field :token,
2021-10-27 15:23:28 +05:30
GraphQL::Types::String,
2021-09-04 01:27:46 +05:30
null: true,
2021-10-27 15:23:28 +05:30
description: 'Runner token after mutation.'
2021-09-04 01:27:46 +05:30
def resolve(**args)
{
token: reset_token(**args),
errors: []
}
end
private
def find_object(type:, **args)
id = args[:id]
case type
when 'group_type'
GitlabSchema.object_from_id(id, expected_type: ::Group)
when 'project_type'
GitlabSchema.object_from_id(id, expected_type: ::Project)
end
end
def reset_token(type:, **args)
id = args[:id]
2022-05-07 20:08:51 +05:30
scope = nil
2021-09-04 01:27:46 +05:30
case type
when 'instance_type'
raise Gitlab::Graphql::Errors::ArgumentError, "id must not be specified for '#{type}' scope" if id.present?
2022-05-07 20:08:51 +05:30
scope = ApplicationSetting.current
authorize!(scope)
2021-09-04 01:27:46 +05:30
when 'group_type', 'project_type'
2022-05-07 20:08:51 +05:30
scope = authorized_find!(type: type, id: id)
2021-09-04 01:27:46 +05:30
end
2022-05-07 20:08:51 +05:30
::Ci::Runners::ResetRegistrationTokenService.new(scope, current_user).execute if scope
2021-09-04 01:27:46 +05:30
end
end
end
end
end