File: //snap/google-cloud-cli/current/lib/googlecloudsdk/command_lib/datastore/flags.py
# -*- coding: utf-8 -*- #
# Copyright 2016 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.
"""Flags and helpers for the datastore related commands."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.calliope import arg_parsers
from googlecloudsdk.calliope import parser_arguments
def AddEntityFilterFlags(parser: parser_arguments.ArgumentInterceptor) -> None:
"""Adds flags for entity filters to the given parser."""
parser.add_argument(
'--kinds',
metavar='KIND',
type=arg_parsers.ArgList(),
help="""
A list specifying what kinds will be included in the operation. When
omitted, all Kinds are included. For example, to operate on only the
'Customer' and 'Order' Kinds:
$ {command} --kinds='Customer','Order'
""",
)
parser.add_argument(
'--namespaces',
metavar='NAMESPACE',
type=arg_parsers.ArgList(),
help="""
A list specifying what namespaces will be included in the operation.
When omitted, all namespaces are included in the operation,
including the default namespace. To specify that *only* the default
namespace should be operated on, use the special symbol '(default)'.
For example, to operate on entities from both the 'customers' and default
namespaces:
$ {command} --namespaces='(default)','customers'
""",
)
def AddLabelsFlag(parser: parser_arguments.ArgumentInterceptor) -> None:
"""Adds an --operation-labels flag to the given parser."""
parser.add_argument(
'--operation-labels',
metavar='OPERATION_LABEL',
type=arg_parsers.ArgDict(),
help="""
A string:string map of custom labels to associate with this operation.
For example:
$ {command} --operation-labels=comment='customer orders','sales rep'=pending
""",
)
def AddIndexFileFlag(parser: parser_arguments.ArgumentInterceptor) -> None:
"""Adds an index_file flag to the given parser.
Args:
parser: The argparse parser.
"""
parser.add_argument(
'index_file',
help="""
The path to your `index.yaml` file. For a detailed look into defining
your `index.yaml` file, refer to this configuration guide:
https://cloud.google.com/datastore/docs/tools/indexconfig#Datastore_About_index_yaml
""",
)
def AddDatabaseIdFlag(parser: parser_arguments.ArgumentInterceptor) -> None:
"""Adds a --database flag to the given parser.
Args:
parser: The argparse parser.
"""
parser.add_argument(
'--database',
help="""\
The database to operate on. If not specified, the CLI refers the
`(default)` database by default.
For example, to operate on database `testdb`:
$ {command} --database='testdb'
""",
)
def AddOperationNameFlag(
parser: parser_arguments.ArgumentInterceptor, operation_type: str
) -> None:
"""Adds a name flag to the given parser.
Args:
parser: The argparse parser.
operation_type: The operate type displayed in help text, a str.
"""
parser.add_argument(
'name',
type=str,
default=None,
help="""
The unique name of the Operation to {}, formatted as either the full
or relative resource path:
projects/my-app-id/operations/foo
or:
foo
""".format(operation_type),
)