File: //snap/google-cloud-cli/current/lib/surface/resource_manager/settings/update.py
# -*- coding: utf-8 -*- #
# Copyright 2024 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Set-policy command for the Resource Settings CLI."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from argcomplete import completers
from googlecloudsdk.api_lib.resource_manager.settings import service
from googlecloudsdk.api_lib.resource_manager.settings import utils as api_utils
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.resource_manager.settings import exceptions
from googlecloudsdk.command_lib.resource_manager.settings import utils
@base.Hidden
@base.DefaultUniverseOnly
@base.ReleaseTracks(base.ReleaseTrack.ALPHA)
class Update(base.Command):
r"""Update the value of a resource setting.
Update the value of a resource setting.
## EXAMPLES
To set the resource setting from the file with the path ``./sample_path'',
run:
$ {command} --setting-from-file="./test_input.json"
"""
@staticmethod
def Args(parser):
parser.add_argument(
'--setting-from-file',
metavar='setting-from-file',
completer=completers.FilesCompleter,
required=True,
help='Path to JSON or YAML file that contains the resource setting.')
def Run(self, args):
"""Creates or updates a setting from a JSON or YAML file.
Args:
args: argparse.Namespace, An object that contains the values for the
arguments specified in the Args method.
Returns:
The created or updated setting.
"""
settings_message = service.ResourceSettingsMessages()
# TODO(b/379282601): Instead of taking all input from file , if we can use flags
input_setting = utils.GetMessageFromFile(
args.setting_from_file, settings_message.Setting)
if not input_setting.name:
raise exceptions.InvalidInputError(
'Name field not present in the resource setting.')
if not utils.ValidateSettingPath(input_setting.name):
raise exceptions.InvalidInputError('Name field has invalid syntax')
resource_type = utils.GetResourceTypeFromString(input_setting.name)
settings_service = api_utils.GetServiceFromResourceType(resource_type)
# Syntax: [organizations|folders|projects]/{resource_id}/
# settings/{setting_name}
setting_path = input_setting.name
etag = input_setting.etag if hasattr(input_setting, 'etag') else None
update_request = api_utils.GetPatchRequestFromResourceType(
resource_type, setting_path, input_setting.value, etag)
update_response = settings_service.Patch(update_request)
return update_response