File: //snap/google-cloud-cli/394/lib/surface/resource_manager/folders/search.py
# -*- coding: utf-8 -*- #
# Copyright 2022 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 search folders associated with the active user."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
import sys
from apitools.base.py import list_pager
from googlecloudsdk.api_lib.resource_manager import folders
from googlecloudsdk.calliope import arg_parsers
from googlecloudsdk.calliope import base
@base.ReleaseTracks(base.ReleaseTrack.ALPHA)
class Search(base.Command):
"""Search folders matching the specified query.
You can specify the maximum number of folders to return in the result
using the `--limit`flag.
## EXAMPLES
The following command lists the folders that have been marked for deletion:
$ {command} --query='state:DELETE_REQUESTED'
Folders with their displayNames starting with sun like sunflower-folder,
sunburn-folder etc. can be listed using the below command
$ {command} --query='displayName:sun*'
"""
FOLDERS_API_VERSION = 'v3'
@staticmethod
def Args(parser):
parser.display_info.AddFormat("""
table(
displayName,
name,
parent,
state
)
""")
base.LIMIT_FLAG.AddToParser(parser)
base.SORT_BY_FLAG.AddToParser(parser)
parser.add_argument(
'--query',
help="""\
A boolean expression for the search criteria used to select the folders to return.
If no search criteria is specified then all accessible projects will be returned.
Query expressions can be used to restrict results based upon displayName, state
and parent, where the operators `=` (`:`) `NOT`, `AND` and `OR` can be used along
with the suffix wildcard symbol `*`. The `displayName` field in a query expression should
use escaped quotes for values that include whitespace to prevent unexpected behavior.
For more details and fields supported by the query expression please refer
query parameters section `[here]
(https://cloud.google.com/resource-manager/reference/rest/v3/folders/search#query-parameters)`
""")
parser.add_argument(
'--page-size',
type=arg_parsers.BoundedInt(1, sys.maxsize, unlimited=True),
require_coverage_in_tests=False,
category=base.LIST_COMMAND_FLAGS,
help="""\
This flag specifies the maximum number of folders per page.
""")
def Run(self, args):
"""Run the search command."""
return list_pager.YieldFromList(
folders.FoldersService(self.FOLDERS_API_VERSION),
folders.FoldersMessages(
self.FOLDERS_API_VERSION).CloudresourcemanagerFoldersSearchRequest(
query=args.query),
method='Search',
limit=args.limit,
batch_size_attribute='pageSize',
batch_size=args.page_size,
field='folders')