2021-01-03 14:25:43 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module NamespaceSettings
|
|
|
|
class UpdateService
|
|
|
|
include ::Gitlab::Allowable
|
|
|
|
|
|
|
|
attr_reader :current_user, :group, :settings_params
|
|
|
|
|
|
|
|
def initialize(current_user, group, settings)
|
|
|
|
@current_user = current_user
|
|
|
|
@group = group
|
|
|
|
@settings_params = settings
|
|
|
|
end
|
|
|
|
|
|
|
|
def execute
|
2021-04-29 21:17:54 +05:30
|
|
|
validate_resource_access_token_creation_allowed_param
|
|
|
|
|
2021-01-03 14:25:43 +05:30
|
|
|
if group.namespace_settings
|
|
|
|
group.namespace_settings.attributes = settings_params
|
|
|
|
else
|
|
|
|
group.build_namespace_settings(settings_params)
|
|
|
|
end
|
|
|
|
end
|
2021-04-29 21:17:54 +05:30
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def validate_resource_access_token_creation_allowed_param
|
|
|
|
return if settings_params[:resource_access_token_creation_allowed].nil?
|
|
|
|
|
|
|
|
unless can?(current_user, :admin_group, group)
|
|
|
|
settings_params.delete(:resource_access_token_creation_allowed)
|
|
|
|
group.namespace_settings.errors.add(:resource_access_token_creation_allowed, _('can only be changed by a group admin.'))
|
|
|
|
end
|
|
|
|
end
|
2021-01-03 14:25:43 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
NamespaceSettings::UpdateService.prepend_if_ee('EE::NamespaceSettings::UpdateService')
|