
    7                         d Z ddlmZ ddlmZ ddlmZ ddlmZ ddlmZ ddlm	Z	 dd	d
Z
d Zd Z e	j                  e	j                  j                         G d de	j                                Zy)z5Command to call batch get Effective IAM Policies API.    )absolute_import)division)unicode_literals)client_util)arg_parsers)basez?    Batch get effective IAM policies that match a request.
    a      To list effective IAM policies of 1 resource in an organization, run:

      $ {command} --scope=organizations/YOUR_ORG_ID --names=RESOURCE_NAME1

    To list effective IAM policies of 2 resources in a folder, run:

      $ {command} --scope=folders/YOUR_FOLDER_ID --names=RESOURCE_NAME1,RESOURCE_NAME2

    To list effective IAM policies of 3 resources in a project using project ID, run:

      $ {command} --scope=projects/YOUR_PROJECT_ID --names=RESOURCE_NAME1,RESOURCE_NAME2,RESOURCE_NAME3

    To list effective IAM policies of 2 resources in a project using project number, run:

      $ {command} --scope=projects/YOUR_PROJECT_NUMBER --names=RESOURCE_NAME1,RESOURCE_NAME2
    )DESCRIPTIONEXAMPLESc                 .    | j                  dddd       y )Nz--scopeSCOPETa          Scope can be a project, a folder, or an organization. The search is
        limited to the IAM policies within this scope. The caller must be
        granted the ``cloudasset.assets.analyzeIamPolicy'',
        ``cloudasset.assets.searchAllResources'',
        ``cloudasset.assets.searchAllIamPolicies'' permissions
        on the desired scope.

        The allowed values are:

          * ```projects/{PROJECT_ID}``` (e.g. ``projects/foo-bar'')
          * ```projects/{PROJECT_NUMBER}``` (e.g. ``projects/12345678'')
          * ```folders/{FOLDER_NUMBER}``` (e.g. ``folders/1234567'')
          * ```organizations/{ORGANIZATION_NUMBER}``` (e.g. ``organizations/123456'')
        )metavarrequiredhelp)add_argumentparsers    -lib/surface/asset/get_effective_iam_policy.pyAddScopeArgumentr   4   s#    	      c                 Z    | j                  ddt        j                  dd      dd       y )	Nz--namesNAMES      )
min_length
max_lengthTa          Names refer to a list of
        [full resource names](https://cloud.google.com/asset-inventory/docs/resource-name-format)
        of [searchable asset types](https://cloud.google.com/asset-inventory/docs/supported-asset-types).
        For each batch call, total number of names provided is between 1 and 20.

        The example value is:

          * ```//cloudsql.googleapis.com/projects/{PROJECT_ID}/instances/{INSTANCE}```
          (e.g. ``//cloudsql.googleapis.com/projects/probe-per-rt-project/instances/instance1'')
        )r   typer   r   )r   r   ArgListr   s    r   AddNamesArgumentr   J   s3    !;
  r   c                   *    e Zd ZdZeZed        Zd Zy)EffectiveIAMPolicyGAzGet effective IAM policies for a specified list of resources within accessible scope, such as a project, folder or organization.c                 0    t        |        t        |        y N)r   r   r   s    r   ArgszEffectiveIAMPolicyGA.Argsf   s    VVr   c                 L    t        j                         }|j                  |      S r"   )r   EffectiveIAMPolicyClientBatchGetEffectiveIAMPolicies)selfargsclients      r   RunzEffectiveIAMPolicyGA.Runk   s!    113F..t44r   N)	__name__
__module____qualname____doc__DETAILED_HELPdetailed_helpstaticmethodr#   r*    r   r   r    r    `   s$     I- 5r   r    N)r.   
__future__r   r   r   googlecloudsdk.api_lib.assetr   googlecloudsdk.callioper   r   r/   r   r   ReleaseTracksReleaseTrackGACommandr    r2   r   r   <module>r:      so    < &  ' 4 / (
		4,, D%%(()54<< 5 *5r   