# frozen_string_literal: true module Mutations module DependencyProxy module GroupSettings class Update < Mutations::BaseMutation graphql_name 'UpdateDependencyProxySettings' include Mutations::ResolvesGroup 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.' 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