2021-11-18 22:05:49 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module Mutations
|
|
|
|
module DependencyProxy
|
|
|
|
module GroupSettings
|
|
|
|
class Update < Mutations::BaseMutation
|
|
|
|
graphql_name 'UpdateDependencyProxySettings'
|
|
|
|
|
2022-04-04 11:22:00 +05:30
|
|
|
include Mutations::ResolvesGroup
|
|
|
|
|
2022-10-11 01:57:18 +05:30
|
|
|
description 'These settings can be adjusted by the group Owner or Maintainer. However, in GitLab 16.0, we ' \
|
|
|
|
'will be limiting this to the Owner role. ' \
|
|
|
|
'[GitLab-#364441](https://gitlab.com/gitlab-org/gitlab/-/issues/364441) proposes making ' \
|
|
|
|
'this change to match the permissions level in the user interface.'
|
|
|
|
|
2021-11-18 22:05:49 +05:30
|
|
|
authorize :admin_dependency_proxy
|
|
|
|
|
|
|
|
argument :group_path,
|
|
|
|
GraphQL::Types::ID,
|
|
|
|
required: true,
|
|
|
|
description: 'Group path for the group dependency proxy.'
|
|
|
|
|
|
|
|
argument :enabled,
|
|
|
|
GraphQL::Types::Boolean,
|
|
|
|
required: false,
|
|
|
|
description: copy_field_description(Types::DependencyProxy::ImageTtlGroupPolicyType, :enabled)
|
|
|
|
|
|
|
|
field :dependency_proxy_setting,
|
|
|
|
Types::DependencyProxy::GroupSettingType,
|
|
|
|
null: true,
|
|
|
|
description: 'Group dependency proxy settings after mutation.'
|
|
|
|
|
|
|
|
def resolve(group_path:, **args)
|
|
|
|
group = authorized_find!(group_path: group_path)
|
|
|
|
|
|
|
|
result = ::DependencyProxy::GroupSettings::UpdateService
|
|
|
|
.new(container: group, current_user: current_user, params: args)
|
|
|
|
.execute
|
|
|
|
|
|
|
|
{
|
|
|
|
dependency_proxy_setting: result.payload[:dependency_proxy_setting],
|
|
|
|
errors: result.errors
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def find_object(group_path:)
|
|
|
|
resolve_group(full_path: group_path)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|