diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2022-06-20 14:10:13 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2022-06-20 14:10:13 +0300 |
commit | 0ea3fcec397b69815975647f5e2aa5fe944a8486 (patch) | |
tree | 7979381b89d26011bcf9bdc989a40fcc2f1ed4ff /app/services/packages/cleanup/update_policy_service.rb | |
parent | 72123183a20411a36d607d70b12d57c484394c8e (diff) |
Add latest changes from gitlab-org/gitlab@15-1-stable-eev15.1.0-rc42
Diffstat (limited to 'app/services/packages/cleanup/update_policy_service.rb')
-rw-r--r-- | app/services/packages/cleanup/update_policy_service.rb | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/app/services/packages/cleanup/update_policy_service.rb b/app/services/packages/cleanup/update_policy_service.rb new file mode 100644 index 00000000000..6744accc007 --- /dev/null +++ b/app/services/packages/cleanup/update_policy_service.rb @@ -0,0 +1,35 @@ +# frozen_string_literal: true + +module Packages + module Cleanup + class UpdatePolicyService < BaseProjectService + ALLOWED_ATTRIBUTES = %i[keep_n_duplicated_package_files].freeze + + def execute + return ServiceResponse.error(message: 'Access denied') unless allowed? + + if policy.update(policy_params) + ServiceResponse.success(payload: { packages_cleanup_policy: policy }) + else + ServiceResponse.error(message: policy.errors.full_messages.to_sentence || 'Bad request') + end + end + + private + + def policy + strong_memoize(:policy) do + project.packages_cleanup_policy + end + end + + def allowed? + can?(current_user, :admin_package, project) + end + + def policy_params + params.slice(*ALLOWED_ATTRIBUTES) + end + end + end +end |