89 lines
3.1 KiB
Python
89 lines
3.1 KiB
Python
# -*- 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
|