File: //snap/google-cloud-cli/396/lib/surface/metastore/services/delete.py
# -*- coding: utf-8 -*- #
# Copyright 2020 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.
"""Command to delete one or more Dataproc Metastore services."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
import json
from apitools.base.py import exceptions as apitools_exceptions
from googlecloudsdk.api_lib.metastore import services_util as services_api_util
from googlecloudsdk.api_lib.metastore import util as api_util
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.metastore import delete_util
from googlecloudsdk.command_lib.metastore import resource_args
from googlecloudsdk.command_lib.metastore import util as command_util
from googlecloudsdk.core import log
from googlecloudsdk.core.console import console_io
DETAILED_HELP = {
'EXAMPLES':
"""\
To delete a Dataproc Metastore service with the name
`my-metastore-service` in location `us-central1`, run:
$ {command} my-metastore-service --location=us-central1
To delete multiple Dataproc Metastore services with the name
`service-1` and `service-2` in the same location
`us-central1`, run:
$ {command} service-1 service-2 --location=us-central1
"""
}
@base.DefaultUniverseOnly
@base.ReleaseTracks(
base.ReleaseTrack.ALPHA, base.ReleaseTrack.BETA, base.ReleaseTrack.GA
)
class Delete(base.DeleteCommand):
"""Delete one or more Dataproc Metastore services.
If run asynchronously with `--async`, exits after printing
one or more operation names that can be used to poll the status of the
deletion(s) via:
{top_command} metastore operations describe
"""
detailed_help = DETAILED_HELP
@staticmethod
def Args(parser):
resource_args.AddServiceResourceArg(
parser, 'to delete', plural=True, required=True, positional=True)
base.ASYNC_FLAG.AddToParser(parser)
def Run(self, args):
env_refs = args.CONCEPTS.services.Parse()
console_io.PromptContinue(
message=command_util.ConstructList('Deleting the following services:', [
'[{}] in [{}]'.format(env_ref.servicesId, env_ref.locationsId)
for env_ref in env_refs
]),
cancel_on_no=True,
cancel_string='Deletion aborted by user.',
throw_if_unattended=True)
waiter = delete_util.ServiceDeletionWaiter(
release_track=self.ReleaseTrack())
encountered_errors = False
for env_ref in env_refs:
operation = None
failed = None
try:
operation = services_api_util.Delete(
env_ref.RelativeName(), release_track=self.ReleaseTrack())
except apitools_exceptions.HttpError as e:
failed = json.loads(e.content)['error']['message']
encountered_errors = True
else:
details = 'with operation [{0}]'.format(operation.name)
waiter.AddPendingDelete(
service_name=env_ref.RelativeName(), operation=operation)
finally:
log.DeletedResource(
env_ref.RelativeName(),
kind='service',
is_async=True,
details=None if encountered_errors else
'with operation [{0}]'.format(operation.name),
failed=failed)
if not args.async_:
encountered_errors = waiter.Wait() or encountered_errors
if encountered_errors:
raise api_util.ServiceDeleteError(
'Some requested deletions did not succeed.')