# -*- coding: utf-8 -*- # # Copyright 2023 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. """Exports a Gcloud Deploy automation resource.""" import textwrap from googlecloudsdk.api_lib.clouddeploy import automation from googlecloudsdk.api_lib.util import exceptions as gcloud_exception from googlecloudsdk.calliope import base from googlecloudsdk.command_lib.deploy import exceptions as deploy_exceptions from googlecloudsdk.command_lib.deploy import export_util from googlecloudsdk.command_lib.deploy import manifest_util from googlecloudsdk.command_lib.deploy import resource_args from googlecloudsdk.command_lib.export import util as core_export_util _DETAILED_HELP = { 'DESCRIPTION': '{description}', 'EXAMPLES': textwrap.dedent("""\ To return the YAML definition of the automation `test-automation` of delivery pipeline `test-pipeline`, in region `us-central1`, run: $ {command} test-automation --delivery-pipeline=test-pipeline --region=us-central1 """), } @base.ReleaseTracks( base.ReleaseTrack.ALPHA, base.ReleaseTrack.BETA, base.ReleaseTrack.GA ) @base.DefaultUniverseOnly class Export(base.ExportCommand): """Returns the YAML definition of the specified Automation. The exported yaml definition can be applied by using the `deploy apply` command. """ detailed_help = _DETAILED_HELP @staticmethod def Args(parser): resource_args.AddAutomationResourceArg(parser, positional=True) core_export_util.AddExportFlags(parser) @gcloud_exception.CatchHTTPErrorRaiseHTTPException( deploy_exceptions.HTTP_ERROR_FORMAT ) def Run(self, args): """Entry point of the export command. Args: args: argparse.Namespace, An object that contains the values for the arguments specified in the .Args() method. """ resource_ref = args.CONCEPTS.automation.Parse() resource = automation.AutomationsClient().Get(resource_ref.RelativeName()) manifest = manifest_util.ProtoToManifest( resource, resource_ref, manifest_util.ResourceKind.AUTOMATION ) export_util.Export(manifest, args)