File: //snap/google-cloud-cli/current/lib/surface/recommender/recommendations/mark_claimed.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.
"""recommender API recommendations list command."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.recommender import recommendation
from googlecloudsdk.calliope import arg_parsers
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.recommender import flags
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.BETA,
base.ReleaseTrack.GA)
class MarkClaimed(base.Command):
r"""Mark a recommendation's state as CLAIMED.
Mark a recommendation's state as CLAIMED. Can be applied to
recommendations in
CLAIMED, SUCCEEDED, FAILED, or ACTIVE state. Users can use this method to
indicate to the Recommender API that they are starting to apply the
recommendation themselves. This stops the recommendation content from
being updated.
## EXAMPLES
To mark a recommendation as CLAIMED:
$ {command} abcd-1234 --project=project-id --location=global
--recommender=google.compute.instance.MachineTypeRecommender --etag=abc123
--state-metadata=key1=value1,key2=value2
"""
@staticmethod
def Args(parser):
"""Args is called by calliope to gather arguments for this command.
Args:
parser: An argparse parser that you can use to add arguments that go on
the command line after this command.
"""
flags.AddParentFlagsToParser(parser)
parser.add_argument(
'RECOMMENDATION',
type=str,
help='Recommendation id which will be marked as claimed')
parser.add_argument(
'--location', metavar='LOCATION', required=True, help='Location')
parser.add_argument(
'--recommender',
metavar='RECOMMENDER',
required=True,
help='Recommender of recommendation')
parser.add_argument(
'--etag',
metavar='ETAG',
required=True,
help='Etag of a recommendation')
parser.add_argument(
'--state-metadata',
type=arg_parsers.ArgDict(min_length=1),
default={},
help='State metadata for recommendation, in format of --state-metadata=key1=value1,key2=value2',
metavar='KEY=VALUE',
action=arg_parsers.StoreOnceAction)
def Run(self, args):
"""Run 'gcloud recommender recommendations mark-claimed'.
Args:
args: argparse.Namespace, The arguments that this command was invoked
with.
Returns:
The recommendations after being marked as claimed.
"""
client = recommendation.CreateClient(self.ReleaseTrack())
name = flags.GetRecommendationName(args)
return client.MarkClaimed(name, args.state_metadata, args.etag)