
                            S r SSKJr  SSKJr  SSKJr  SSKJr  Sr	 " S S\R                  5      r " S	 S
\R                  5      r " S S\R                  5      r " S S\R                  5      r " S S\R                  5      r " S S\R                  5      r " S S\R                  5      r " S S\R                  5      r " S S\R                  5      r " S S\R                  5      r " S S\R                  5      r " S S\R                  5      r " S S \R                  5      r " S! S"\R                  5      r " S# S$\R                  5      r " S% S&\R                  5      r " S' S(\R                  5      r " S) S*\R                  5      r " S+ S,\R                  5      r " S- S.\R                  5      r " S/ S0\R                  5      r " S1 S2\R                  5      r  " S3 S4\R                  5      r! " S5 S6\R                  5      r"\RF                  " \"S7S85        \RH                  " \"RJ                  S9S:5        \RH                  " \"RJ                  S;S<5        g=)>zGenerated message classes for cloudasset version v1p5beta1.

The cloud asset API manages the history and inventory of cloud resources.
    )absolute_import)messages)encoding)extra_types
cloudassetc                      \ rS rSrSr\R                  " SS5      r\R                  " SS5      r\R                  " SSS	9r
\R                  " S
5      r\R                  " SS5      r\R                  " S5      r\R                  " S5      r\R                  " SSSS	9r\R                  " SS5      r\R                  " SS5      rSrg)Asset   a  An asset in Google Cloud. An asset can be any resource in the Google
Cloud [resource hierarchy](https://cloud.google.com/resource-
manager/docs/cloud-platform-resource-hierarchy), a resource outside the
Google Cloud resource hierarchy (such as Google Kubernetes Engine clusters
and objects), or a policy (e.g. Cloud IAM policy). See [Supported asset
types](https://cloud.google.com/asset-inventory/docs/supported-asset-types)
for more information.

Fields:
  accessLevel: Please also refer to the [access level user
    guide](https://cloud.google.com/access-context-
    manager/docs/overview#access-levels).
  accessPolicy: Please also refer to the [access policy user
    guide](https://cloud.google.com/access-context-
    manager/docs/overview#access-policies).
  ancestors: The ancestry path of an asset in Google Cloud [resource
    hierarchy](https://cloud.google.com/resource-manager/docs/cloud-
    platform-resource-hierarchy), represented as a list of relative resource
    names. An ancestry path starts with the closest ancestor in the
    hierarchy and ends at root. If the asset is a project, folder, or
    organization, the ancestry path starts from the asset itself.  Example:
    `["projects/123456789", "folders/5432", "organizations/1234"]`
  assetType: The type of the asset. Example: `compute.googleapis.com/Disk`
    See [Supported asset types](https://cloud.google.com/asset-
    inventory/docs/supported-asset-types) for more information.
  iamPolicy: A representation of the Cloud IAM policy set on a Google Cloud
    resource. There can be a maximum of one Cloud IAM policy set on any
    given resource. In addition, Cloud IAM policies inherit their granted
    access scope from any policies set on parent resources in the resource
    hierarchy. Therefore, the effectively policy is the union of both the
    policy set on this resource and each policy set on all of the resource's
    ancestry resource levels in the hierarchy. See [this
    topic](https://cloud.google.com/iam/docs/policies#inheritance) for more
    information.
  iamPolicyName: The name of the Cloud IAM policy set on a Google Cloud
    resource. There can be a maximum of one Cloud IAM policy set on any
    given resource.
  name: The full name of the asset. Example: `//compute.googleapis.com/proje
    cts/my_project_123/zones/zone1/instances/instance1`  See [Resource names
    ](https://cloud.google.com/apis/design/resource_names#full_resource_name
    ) for more information.
  orgPolicy: A representation of an [organization
    policy](https://cloud.google.com/resource-manager/docs/organization-
    policy/overview#organization_policy). There can be more than one
    organization policy with different constraints set on a given resource.
  resource: A representation of the resource.
  servicePerimeter: Please also refer to the [service perimeter user
    guide](https://cloud.google.com/vpc-service-controls/docs/overview).
/GoogleIdentityAccesscontextmanagerV1AccessLevel   0GoogleIdentityAccesscontextmanagerV1AccessPolicy      Trepeated   Policy         GoogleCloudOrgpolicyV1Policy   Resource	   4GoogleIdentityAccesscontextmanagerV1ServicePerimeter
    N)__name__
__module____qualname____firstlineno____doc__	_messagesMessageFieldaccessLevelaccessPolicyStringField	ancestors	assetType	iamPolicy
BytesFieldiamPolicyNamename	orgPolicyresourceservicePerimeter__static_attributes__r       _lib/googlecloudsdk/generated_clients/apis/cloudasset/v1p5beta1/cloudasset_v1p5beta1_messages.pyr	   r	      s    0d &&'XZ[\+''(Z\]^,##A5)##A&)$$Xq1)&&q)-			q	!$$$%CQQUV)##J2(++,bdfgr2   r	   c                   `    \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	Sr
g	)
AuditConfigP   a  Specifies the audit configuration for a service. The configuration
determines which permission types are logged, and what identities, if any,
are exempted from logging. An AuditConfig must have one or more
AuditLogConfigs.  If there are AuditConfigs for both `allServices` and a
specific service, the union of the two AuditConfigs is used for that
service: the log_types specified in each AuditConfig are enabled, and the
exempted_members in each AuditLogConfig are exempted.  Example Policy with
multiple AuditConfigs:      {       "audit_configs": [         {
"service": "allServices",           "audit_log_configs": [             {
"log_type": "DATA_READ",               "exempted_members": [
"user:jose@example.com"               ]             },             {
"log_type": "DATA_WRITE"             },             {
"log_type": "ADMIN_READ"             }           ]         },         {
"service": "sampleservice.googleapis.com",           "audit_log_configs": [
{               "log_type": "DATA_READ"             },             {
"log_type": "DATA_WRITE",               "exempted_members": [
"user:aliya@example.com"               ]             }           ]         }
]     }  For sampleservice, this policy enables DATA_READ, DATA_WRITE and
ADMIN_READ logging. It also exempts jose@example.com from DATA_READ logging,
and aliya@example.com from DATA_WRITE logging.

Fields:
  auditLogConfigs: The configuration for logging of each type of permission.
  service: Specifies a service that will be enabled for audit logging. For
    example, `storage.googleapis.com`, `cloudsql.googleapis.com`.
    `allServices` is a special value that covers all services.
AuditLogConfigr   Tr   r   r   N)r   r   r    r!   r"   r#   r$   auditLogConfigsr'   servicer1   r   r2   r3   r5   r5   P   s.    8 **+;QN/!!!$'r2   r5   c                       \ rS rSrSr " S S\R                  5      r\R                  " SSS9r	\R                  " SS5      rS	rg
)r7   q   a  Provides the configuration for logging a type of permissions. Example:
{       "audit_log_configs": [         {           "log_type": "DATA_READ",
"exempted_members": [             "user:jose@example.com"           ]
},         {           "log_type": "DATA_WRITE"         }       ]     }
This enables 'DATA_READ' and 'DATA_WRITE' logging, while exempting
jose@example.com from DATA_READ logging.

Enums:
  LogTypeValueValuesEnum: The log type that this config enables.

Fields:
  exemptedMembers: Specifies the identities that do not cause logging for
    this type of permission. Follows the same format of Binding.members.
  logType: The log type that this config enables.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	%AuditLogConfig.LogTypeValueValuesEnum   a  The log type that this config enables.

Values:
  LOG_TYPE_UNSPECIFIED: Default case. Should never be this.
  ADMIN_READ: Admin reads. Example: CloudIAM getIamPolicy
  DATA_WRITE: Data writes. Example: CloudSQL Users create
  DATA_READ: Data reads. Example: CloudSQL Users list
r   r   r   r   r   N)
r   r   r    r!   r"   LOG_TYPE_UNSPECIFIED
ADMIN_READ
DATA_WRITE	DATA_READr1   r   r2   r3   LogTypeValueValuesEnumr=      s     JJIr2   rC   r   Tr   r   r   N)r   r   r    r!   r"   r#   EnumrC   r'   exemptedMembers	EnumFieldlogTyper1   r   r2   r3   r7   r7   q   s>     y~~  ))!d;/ 8!<'r2   r7   c                       \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	\R                  " S5      r
S	rg
)Binding   a
  Associates `members` with a `role`.

Fields:
  condition: The condition that is associated with this binding.  If the
    condition evaluates to `true`, then this binding applies to the current
    request.  If the condition evaluates to `false`, then this binding does
    not apply to the current request. However, a different role binding
    might grant the same role to one or more of the members in this binding.
    To learn which resources support conditions in their IAM policies, see
    the [IAM
    documentation](https://cloud.google.com/iam/help/conditions/resource-
    policies).
  members: Specifies the identities requesting access for a Cloud Platform
    resource. `members` can have the following values:  * `allUsers`: A
    special identifier that represents anyone who is    on the internet;
    with or without a Google account.  * `allAuthenticatedUsers`: A special
    identifier that represents anyone    who is authenticated with a Google
    account or a service account.  * `user:{emailid}`: An email address that
    represents a specific Google    account. For example,
    `alice@example.com` .   * `serviceAccount:{emailid}`: An email address
    that represents a service    account. For example, `my-other-
    app@appspot.gserviceaccount.com`.  * `group:{emailid}`: An email address
    that represents a Google group.    For example, `admins@example.com`.  *
    `deleted:user:{emailid}?uid={uniqueid}`: An email address (plus unique
    identifier) representing a user that has been recently deleted. For
    example, `alice@example.com?uid=123456789012345678901`. If the user is
    recovered, this value reverts to `user:{emailid}` and the recovered user
    retains the role in the binding.  *
    `deleted:serviceAccount:{emailid}?uid={uniqueid}`: An email address
    (plus    unique identifier) representing a service account that has been
    recently    deleted. For example,    `my-other-
    app@appspot.gserviceaccount.com?uid=123456789012345678901`.    If the
    service account is undeleted, this value reverts to
    `serviceAccount:{emailid}` and the undeleted service account retains the
    role in the binding.  * `deleted:group:{emailid}?uid={uniqueid}`: An
    email address (plus unique    identifier) representing a Google group
    that has been recently    deleted. For example,
    `admins@example.com?uid=123456789012345678901`. If    the group is
    recovered, this value reverts to `group:{emailid}` and the    recovered
    group retains the role in the binding.   * `domain:{domain}`: The G
    Suite domain (primary) that represents all the    users of that domain.
    For example, `google.com` or `example.com`.
  role: Role that is assigned to `members`. For example, `roles/viewer`,
    `roles/editor`, or `roles/owner`.
Exprr   r   Tr   r   r   N)r   r   r    r!   r"   r#   r$   	conditionr'   membersroler1   r   r2   r3   rI   rI      s>    ,\ $$VQ/)!!!d3'			q	!$r2   rI   c                   >   \ rS rSrSr " S S\R                  5      r\R                  " SSS9r	\R                  " SS5      r\R                  " S	\R                  R                  S
9r\R                  " S5      r\R                  " SSS9r\R                  " S5      rSrg)CloudassetAssetsListRequest   av  A CloudassetAssetsListRequest object.

Enums:
  ContentTypeValueValuesEnum: Asset content type. If not specified, no
    content but the asset name will be returned.

Fields:
  assetTypes: A list of asset types of which to take a snapshot for. For
    example: "compute.googleapis.com/Disk". If specified, only matching
    assets will be returned. See [Introduction to Cloud Asset
    Inventory](https://cloud.google.com/resource-manager/docs/cloud-asset-
    inventory/overview) for all supported asset types.
  contentType: Asset content type. If not specified, no content but the
    asset name will be returned.
  pageSize: The maximum number of assets to be returned in a single
    response. Default is 100, minimum is 1, and maximum is 1000.
  pageToken: The `next_page_token` returned from the previous
    `ListAssetsResponse`, or unspecified for the first `ListAssetsRequest`.
    It is a continuation of a prior `ListAssets` call, and the API should
    return the next page of assets.
  parent: Required. Name of the organization or project the assets belong
    to. Format: "organizations/[organization-number]" (such as
    "organizations/123"), "projects/[project-number]" (such as "projects/my-
    project-id"), or "projects/[project-id]" (such as "projects/12345").
  readTime: Timestamp to take an asset snapshot. This can only be set to a
    timestamp between the current time and the current time minus 35 days
    (inclusive). If not specified, the current time will be used. Due to
    delays in resource data collection and indexing, there is a volatile
    window during which running the same query may get different results.
c                   0    \ rS rSrSrSrSrSrSrSr	Sr
S	rg
)6CloudassetAssetsListRequest.ContentTypeValueValuesEnum   a-  Asset content type. If not specified, no content but the asset name
will be returned.

Values:
  CONTENT_TYPE_UNSPECIFIED: <no description>
  RESOURCE: <no description>
  IAM_POLICY: <no description>
  IAM_POLICY_NAME: <no description>
  ORG_POLICY: <no description>
  ACCESS_POLICY: <no description>
r   r   r   r   r   r   r   N)r   r   r    r!   r"   CONTENT_TYPE_UNSPECIFIEDRESOURCE
IAM_POLICYIAM_POLICY_NAME
ORG_POLICYACCESS_POLICYr1   r   r2   r3   ContentTypeValueValuesEnumrS      s(    
  !HJOJMr2   r[   r   Tr   r   r   variantr   r   )requiredr   r   N)r   r   r    r!   r"   r#   rD   r[   r'   
assetTypesrF   contentTypeIntegerFieldVariantINT32pageSize	pageTokenparentreadTimer1   r   r2   r3   rP   rP      s    >9>> & $$Q6*##$@!D+##Ay/@/@/F/FG(##A&)  T2&""1%(r2   rP   c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S5      r	\R                  " S5      r
Srg)	rK   i  a  Represents a textual expression in the Common Expression Language (CEL)
syntax. CEL is a C-like expression language. The syntax and semantics of CEL
are documented at https://github.com/google/cel-spec.  Example (Comparison):
title: "Summary size limit"     description: "Determines if a summary is
less than 100 chars"     expression: "document.summary.size() < 100"
Example (Equality):      title: "Requestor is owner"     description:
"Determines if requestor is the document owner"     expression:
"document.owner == request.auth.claims.email"  Example (Logic):      title:
"Public documents"     description: "Determine whether the document should
be publicly visible"     expression: "document.type != 'private' &&
document.type != 'internal'"  Example (Data Manipulation):      title:
"Notification string"     description: "Create a notification string with a
timestamp."     expression: "'New message received at ' +
string(document.create_time)"  The exact variables and functions that may be
referenced within an expression are determined by the service that evaluates
it. See the service documentation for additional information.

Fields:
  description: Optional. Description of the expression. This is a longer
    text which describes the expression, e.g. when hovered over it in a UI.
  expression: Textual representation of an expression in Common Expression
    Language syntax.
  location: Optional. String indicating the location of the expression for
    error reporting, e.g. a file name and a position in the file.
  title: Optional. Title for the expression, i.e. a short string describing
    its purpose. This can be used e.g. in UIs which allow to enter the
    expression.
r   r   r   r   r   N)r   r   r    r!   r"   r#   r'   description
expressionlocationtitler1   r   r2   r3   rK   rK     sI    : %%a(+$$Q'*""1%(



"%r2   rK   c                   <    \ rS rSrSr\R                  " S5      rSrg)#GoogleCloudOrgpolicyV1BooleanPolicyi'  a  Used in `policy_type` to specify how `boolean_policy` will behave at
this resource.

Fields:
  enforced: If `true`, then the `Policy` is enforced. If `false`, then any
    configuration is acceptable.  Suppose you have a `Constraint`
    `constraints/compute.disableSerialPortAccess` with `constraint_default`
    set to `ALLOW`. A `Policy` for that `Constraint` exhibits the following
    behavior:   - If the `Policy` at this resource has enforced set to
    `false`, serial     port connection attempts will be allowed.   - If the
    `Policy` at this resource has enforced set to `true`, serial     port
    connection attempts will be refused.   - If the `Policy` at this
    resource is `RestoreDefault`, serial port     connection attempts will
    be allowed.   - If no `Policy` is set at this resource or anywhere
    higher in the     resource hierarchy, serial port connection attempts
    will be allowed.   - If no `Policy` is set at this resource, but one
    exists higher in the     resource hierarchy, the behavior is as if
    the`Policy` were set at     this resource.  The following examples
    demonstrate the different possible layerings:  Example 1 (nearest
    `Constraint` wins):   `organizations/foo` has a `Policy` with:
    {enforced: false}   `projects/bar` has no `Policy` set. The constraint
    at `projects/bar` and `organizations/foo` will not be enforced.  Example
    2 (enforcement gets replaced):   `organizations/foo` has a `Policy`
    with:     {enforced: false}   `projects/bar` has a `Policy` with:
    {enforced: true} The constraint at `organizations/foo` is not enforced.
    The constraint at `projects/bar` is enforced.  Example 3
    (RestoreDefault):   `organizations/foo` has a `Policy` with:
    {enforced: true}   `projects/bar` has a `Policy` with:
    {RestoreDefault: {}} The constraint at `organizations/foo` is enforced.
    The constraint at `projects/bar` is not enforced, because
    `constraint_default` for the `Constraint` is `ALLOW`.
r   r   N)	r   r   r    r!   r"   r#   BooleanFieldenforcedr1   r   r2   r3   rn   rn   '  s    B ##A&(r2   rn   c                       \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	\R                  " SSS9r\R                  " S	SS9r\R                  " S
5      r\R                  " S5      rSrg) GoogleCloudOrgpolicyV1ListPolicyiL  a1  Used in `policy_type` to specify how `list_policy` behaves at this
resource.  `ListPolicy` can define specific values and subtrees of Cloud
Resource Manager resource hierarchy (`Organizations`, `Folders`, `Projects`)
that are allowed or denied by setting the `allowed_values` and
`denied_values` fields. This is achieved by using the `under:` and optional
`is:` prefixes. The `under:` prefix is used to denote resource subtree
values. The `is:` prefix is used to denote specific values, and is required
only if the value contains a ":". Values prefixed with "is:" are treated the
same as values with no prefix. Ancestry subtrees must be in one of the
following formats:     - "projects/<project-id>", e.g. "projects/tokyo-
rain-123"     - "folders/<folder-id>", e.g. "folders/1234"     -
"organizations/<organization-id>", e.g. "organizations/1234" The
`supports_under` field of the associated `Constraint`  defines whether
ancestry prefixes can be used. You can set `allowed_values` and
`denied_values` in the same `Policy` if `all_values` is
`ALL_VALUES_UNSPECIFIED`. `ALLOW` or `DENY` are used to allow or deny all
values. If `all_values` is set to either `ALLOW` or `DENY`, `allowed_values`
and `denied_values` must be unset.

Enums:
  AllValuesValueValuesEnum: The policy all_values state.

Fields:
  allValues: The policy all_values state.
  allowedValues: List of values allowed  at this resource. Can only be set
    if `all_values` is set to `ALL_VALUES_UNSPECIFIED`.
  deniedValues: List of values denied at this resource. Can only be set if
    `all_values` is set to `ALL_VALUES_UNSPECIFIED`.
  inheritFromParent: Determines the inheritance behavior for this `Policy`.
    By default, a `ListPolicy` set at a resource supersedes any `Policy` set
    anywhere up the resource hierarchy. However, if `inherit_from_parent` is
    set to `true`, then the values from the effective `Policy` of the parent
    resource are inherited, meaning the values set in this `Policy` are
    added to the values inherited up the hierarchy.  Setting `Policy`
    hierarchies that inherit both allowed values and denied values isn't
    recommended in most circumstances to keep the configuration simple and
    understandable. However, it is possible to set a `Policy` with
    `allowed_values` set that inherits a `Policy` with `denied_values` set.
    In this case, the values that are allowed must be in `allowed_values`
    and not present in `denied_values`.  For example, suppose you have a
    `Constraint` `constraints/serviceuser.services`, which has a
    `constraint_type` of `list_constraint`, and with `constraint_default`
    set to `ALLOW`. Suppose that at the Organization level, a `Policy` is
    applied that restricts the allowed API activations to {`E1`, `E2`}.
    Then, if a `Policy` is applied to a project below the Organization that
    has `inherit_from_parent` set to `false` and field all_values set to
    DENY, then an attempt to activate any API will be denied.  The following
    examples demonstrate different possible layerings for `projects/bar`
    parented by `organizations/foo`:  Example 1 (no inherited values):
    `organizations/foo` has a `Policy` with values:     {allowed_values:
    "E1" allowed_values:"E2"}   `projects/bar` has `inherit_from_parent`
    `false` and values:     {allowed_values: "E3" allowed_values: "E4"} The
    accepted values at `organizations/foo` are `E1`, `E2`. The accepted
    values at `projects/bar` are `E3`, and `E4`.  Example 2 (inherited
    values):   `organizations/foo` has a `Policy` with values:
    {allowed_values: "E1" allowed_values:"E2"}   `projects/bar` has a
    `Policy` with values:     {value: "E3" value: "E4" inherit_from_parent:
    true} The accepted values at `organizations/foo` are `E1`, `E2`. The
    accepted values at `projects/bar` are `E1`, `E2`, `E3`, and `E4`.
    Example 3 (inheriting both allowed and denied values):
    `organizations/foo` has a `Policy` with values:     {allowed_values:
    "E1" allowed_values: "E2"}   `projects/bar` has a `Policy` with:
    {denied_values: "E1"} The accepted values at `organizations/foo` are
    `E1`, `E2`. The value accepted at `projects/bar` is `E2`.  Example 4
    (RestoreDefault):   `organizations/foo` has a `Policy` with values:
    {allowed_values: "E1" allowed_values:"E2"}   `projects/bar` has a
    `Policy` with values:     {RestoreDefault: {}} The accepted values at
    `organizations/foo` are `E1`, `E2`. The accepted values at
    `projects/bar` are either all or none depending on the value of
    `constraint_default` (if `ALLOW`, all; if `DENY`, none).  Example 5 (no
    policy inherits parent policy):   `organizations/foo` has no `Policy`
    set.   `projects/bar` has no `Policy` set. The accepted values at both
    levels are either all or none depending on the value of
    `constraint_default` (if `ALLOW`, all; if `DENY`, none).  Example 6
    (ListConstraint allowing all):   `organizations/foo` has a `Policy` with
    values:     {allowed_values: "E1" allowed_values: "E2"}   `projects/bar`
    has a `Policy` with:     {all: ALLOW} The accepted values at
    `organizations/foo` are `E1`, E2`. Any value is accepted at
    `projects/bar`.  Example 7 (ListConstraint allowing none):
    `organizations/foo` has a `Policy` with values:     {allowed_values:
    "E1" allowed_values: "E2"}   `projects/bar` has a `Policy` with:
    {all: DENY} The accepted values at `organizations/foo` are `E1`, E2`. No
    value is accepted at `projects/bar`.  Example 10 (allowed and denied
    subtrees of Resource Manager hierarchy): Given the following resource
    hierarchy   O1->{F1, F2}; F1->{P1}; F2->{P2, P3},   `organizations/foo`
    has a `Policy` with values:     {allowed_values:
    "under:organizations/O1"}   `projects/bar` has a `Policy` with:
    {allowed_values: "under:projects/P3"}     {denied_values:
    "under:folders/F2"} The accepted values at `organizations/foo` are
    `organizations/O1`,   `folders/F1`, `folders/F2`, `projects/P1`,
    `projects/P2`,   `projects/P3`. The accepted values at `projects/bar`
    are `organizations/O1`,   `folders/F1`, `projects/P1`.
  suggestedValue: Optional. The Google Cloud Console will try to default to
    a configuration that matches the value specified in this `Policy`. If
    `suggested_value` is not set, it will inherit the value specified higher
    in the hierarchy, unless `inherit_from_parent` is `false`.
c                   $    \ rS rSrSrSrSrSrSrg)9GoogleCloudOrgpolicyV1ListPolicy.AllValuesValueValuesEnumi  zThe policy all_values state.

Values:
  ALL_VALUES_UNSPECIFIED: Indicates that allowed_values or denied_values
    must be set.
  ALLOW: A policy with this set allows all values.
  DENY: A policy with this set denies all values.
r   r   r   r   N)	r   r   r    r!   r"   ALL_VALUES_UNSPECIFIEDALLOWDENYr1   r   r2   r3   AllValuesValueValuesEnumrt     s     EDr2   rx   r   r   Tr   r   r   r   r   N)r   r   r    r!   r"   r#   rD   rx   rF   	allValuesr'   allowedValuesdeniedValuesro   inheritFromParentsuggestedValuer1   r   r2   r3   rr   rr   L  ss    `D  !!"<a@)''D9-&&q48,,,Q/((+.r2   rr   c                   @   \ rS rSrSr\R                  " SS5      r\R                  " S5      r	\R                  " S5      r\R                  " SS5      r\R                  " S	S
5      r\R                  " S5      r\R                  " S\R                   R"                  S9rSrg)r   i  a  Defines a Cloud Organization `Policy` which is used to specify
`Constraints` for configurations of Cloud Platform resources.

Fields:
  booleanPolicy: For boolean `Constraints`, whether to enforce the
    `Constraint` or not.
  constraint: The name of the `Constraint` the `Policy` is configuring, for
    example, `constraints/serviceuser.services`.  A [list of available
    constraints](/resource-manager/docs/organization-policy/org-policy-
    constraints) is available.  Immutable after creation.
  etag: An opaque tag indicating the current version of the `Policy`, used
    for concurrency control.  When the `Policy` is returned from either a
    `GetPolicy` or a `ListOrgPolicy` request, this `etag` indicates the
    version of the current `Policy` to use when executing a read-modify-
    write loop.  When the `Policy` is returned from a `GetEffectivePolicy`
    request, the `etag` will be unset.  When the `Policy` is used in a
    `SetOrgPolicy` method, use the `etag` value that was returned from a
    `GetOrgPolicy` request as part of a read-modify-write loop for
    concurrency control. Not setting the `etag`in a `SetOrgPolicy` request
    will result in an unconditional write of the `Policy`.
  listPolicy: List of values either allowed or disallowed.
  restoreDefault: Restores the default behavior of the constraint;
    independent of `Constraint` type.
  updateTime: The time stamp the `Policy` was previously updated. This is
    set by the server, not specified by the caller, and represents the last
    time a call to `SetOrgPolicy` was made for that `Policy`. Any value set
    by the client will be ignored.
  version: Version of the `Policy`. Default version is 0;
rn   r   r   r   rr   r   $GoogleCloudOrgpolicyV1RestoreDefaultr   r   r   r\   r   N)r   r   r    r!   r"   r#   r$   booleanPolicyr'   
constraintr+   etag
listPolicyrestoreDefault
updateTimera   rb   rc   versionr1   r   r2   r3   r   r     s    < (()NPQR-$$Q'*			a	 $%%&H!L*))*PRST.$$Q'*""1i.?.?.E.EF'r2   r   c                       \ rS rSrSrSrg)r   i  a  Ignores policies set above this resource and restores the
`constraint_default` enforcement behavior of the specific `Constraint` at
this resource.  Suppose that `constraint_default` is set to `ALLOW` for the
`Constraint` `constraints/serviceuser.services`. Suppose that organization
foo.com sets a `Policy` at their Organization resource node that restricts
the allowed service activations to deny all service activations. They could
then set a `Policy` with the `policy_type` `restore_default` on several
experimental projects, restoring the `constraint_default` enforcement of the
`Constraint` for only those projects, allowing those projects to have all
services activated.
r   N)r   r   r    r!   r"   r1   r   r2   r3   r   r     s    
r2   r   c                       \ rS rSrSr\R                  " SS5      r\R                  " SS5      r\R                  " S5      r
\R                  " S5      r\R                  " S	5      rS
rg)r   i  a  An `AccessLevel` is a label that can be applied to requests to Google
Cloud services, along with a list of requirements necessary for the label to
be applied.

Fields:
  basic: A `BasicLevel` composed of `Conditions`.
  custom: A `CustomLevel` written in the Common Expression Language.
  description: Description of the `AccessLevel` and its use. Does not affect
    behavior.
  name: Required. Resource name for the Access Level. The `short_name`
    component must begin with a letter and only include alphanumeric and
    '_'. Format: `accessPolicies/{policy_id}/accessLevels/{short_name}`. The
    maximum length of the `short_name` component is 50 characters.
  title: Human readable title. Must be unique within the Policy.
.GoogleIdentityAccesscontextmanagerV1BasicLevelr   /GoogleIdentityAccesscontextmanagerV1CustomLevelr   r   r   r   r   N)r   r   r    r!   r"   r#   r$   basiccustomr'   ri   r-   rl   r1   r   r2   r3   r   r     sa      
 
 !QST
U%!!"SUVW&%%a(+			q	!$



"%r2   r   c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S5      r	\R                  " S5      r
Srg)	r   i  a  `AccessPolicy` is a container for `AccessLevels` (which define the
necessary attributes to use Google Cloud services) and `ServicePerimeters`
(which define regions of services able to freely pass data within a
perimeter). An access policy is globally visible within an organization, and
the restrictions it specifies apply to all projects within an organization.

Fields:
  etag: Output only. An opaque identifier for the current version of the
    `AccessPolicy`. This will always be a strongly validated etag, meaning
    that two Access Polices will be identical if and only if their etags are
    identical. Clients should not expect this to be in any specific format.
  name: Output only. Resource name of the `AccessPolicy`. Format:
    `accessPolicies/{policy_id}`
  parent: Required. The parent of this `AccessPolicy` in the Cloud Resource
    Hierarchy. Currently immutable once created. Format:
    `organizations/{organization_id}`
  title: Required. Human readable title. Does not affect behavior.
r   r   r   r   r   N)r   r   r    r!   r"   r#   r'   r   r-   rf   rl   r1   r   r2   r3   r   r     sI    & 
		q	!$			q	!$  #&



"%r2   r   c                       \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	\R                  " SSSS	9rS
rg)r   i,  a  `BasicLevel` is an `AccessLevel` using a set of recommended features.

Enums:
  CombiningFunctionValueValuesEnum: How the `conditions` list should be
    combined to determine if a request is granted this `AccessLevel`. If AND
    is used, each `Condition` in `conditions` must be satisfied for the
    `AccessLevel` to be applied. If OR is used, at least one `Condition` in
    `conditions` must be satisfied for the `AccessLevel` to be applied.
    Default behavior is AND.

Fields:
  combiningFunction: How the `conditions` list should be combined to
    determine if a request is granted this `AccessLevel`. If AND is used,
    each `Condition` in `conditions` must be satisfied for the `AccessLevel`
    to be applied. If OR is used, at least one `Condition` in `conditions`
    must be satisfied for the `AccessLevel` to be applied. Default behavior
    is AND.
  conditions: Required. A list of requirements for the `AccessLevel` to be
    granted.
c                        \ rS rSrSrSrSrSrg)OGoogleIdentityAccesscontextmanagerV1BasicLevel.CombiningFunctionValueValuesEnumiB  a  How the `conditions` list should be combined to determine if a request
is granted this `AccessLevel`. If AND is used, each `Condition` in
`conditions` must be satisfied for the `AccessLevel` to be applied. If OR
is used, at least one `Condition` in `conditions` must be satisfied for
the `AccessLevel` to be applied. Default behavior is AND.

Values:
  AND: All `Conditions` must be true for the `BasicLevel` to be true.
  OR: If at least one `Condition` is true, then the `BasicLevel` is true.
r   r   r   N)r   r   r    r!   r"   ANDORr1   r   r2   r3    CombiningFunctionValueValuesEnumr   B  s    	 C	
Br2   r   r   -GoogleIdentityAccesscontextmanagerV1Conditionr   Tr   r   N)r   r   r    r!   r"   r#   rD   r   rF   combiningFunctionr$   
conditionsr1   r   r2   r3   r   r   ,  sD    *   ))*LaP%%&UWXcgh*r2   r   c                       \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	\R                  " SSS9r
\R                  " S	5      r\R                  " S
SS9r\R                  " SSS9rSrg)r   iT  a  A condition necessary for an `AccessLevel` to be granted. The Condition
is an AND over its fields. So a Condition is true if: 1) the request IP is
from one of the listed subnetworks AND 2) the originating device complies
with the listed device policy AND 3) all listed access levels are granted
AND 4) the request was sent at a time allowed by the DateTimeRestriction.

Fields:
  devicePolicy: Device specific restrictions, all restrictions must hold for
    the Condition to be true. If not specified, all devices are allowed.
  ipSubnetworks: CIDR block IP subnetwork specification. May be IPv4 or
    IPv6. Note that for a CIDR IP address block, the specified IP address
    portion must be properly truncated (i.e. all the host bits must be zero)
    or the input is considered malformed. For example, "192.0.2.0/24" is
    accepted but "192.0.2.1/24" is not. Similarly, for IPv6, "2001:db8::/32"
    is accepted whereas "2001:db8::1/32" is not. The originating IP of a
    request must be in one of the listed subnets in order for this Condition
    to be true. If empty, all IP addresses are allowed.
  members: The request must be made by one of the provided user or service
    accounts. Groups are not supported. Syntax: `user:{emailid}`
    `serviceAccount:{emailid}` If not specified, a request may come from any
    user.
  negate: Whether to negate the Condition. If true, the Condition becomes a
    NAND over its non-empty fields, each field must be false for the
    Condition overall to be satisfied. Defaults to false.
  regions: The request must originate from one of the provided
    countries/regions. Must be valid ISO 3166-1 alpha-2 codes.
  requiredAccessLevels: A list of other access levels defined in the same
    `Policy`, referenced by resource name. Referencing an `AccessLevel`
    which does not exist is an error. All access levels listed must be
    granted for the Condition to be true. Example:
    "`accessPolicies/MY_POLICY/accessLevels/LEVEL_NAME"`
0GoogleIdentityAccesscontextmanagerV1DevicePolicyr   r   Tr   r   r   r   r   r   N)r   r   r    r!   r"   r#   r$   devicePolicyr'   ipSubnetworksrM   ro   negateregionsrequiredAccessLevelsr1   r   r2   r3   r   r   T  sw    B ''(Z\]^,''D9-!!!d3'!!!$&!!!d3'"..q4@r2   r   c                   >    \ rS rSrSr\R                  " SS5      rSrg)r   i~  a  `CustomLevel` is an `AccessLevel` using the Cloud Common Expression
Language to represent the necessary conditions for the level to apply to a
request. See CEL spec at: https://github.com/google/cel-spec

Fields:
  expr: Required. A Cloud CEL expression evaluating to a boolean.
rK   r   r   N)	r   r   r    r!   r"   r#   r$   exprr1   r   r2   r3   r   r   ~  s     
			*$r2   r   c                   D   \ rS rSrSr " S S\R                  5      r " S S\R                  5      r\R                  " SSSS	9r
\R                  " SS
SS	9r\R                  " SSSS	9r\R                  " S5      r\R                  " S5      r\R                  " S5      rSrg)r   i  a#  `DevicePolicy` specifies device specific restrictions necessary to
acquire a given access level. A `DevicePolicy` specifies requirements for
requests from devices to be granted access levels, it does not do any
enforcement on the device. `DevicePolicy` acts as an AND over all specified
fields, and each repeated field is an OR over its elements. Any unset fields
are ignored. For example, if the proto is { os_type : DESKTOP_WINDOWS,
os_type : DESKTOP_LINUX, encryption_status: ENCRYPTED}, then the
DevicePolicy will be true for requests originating from encrypted Linux
desktops and encrypted Windows desktops.

Enums:
  AllowedDeviceManagementLevelsValueListEntryValuesEnum:
  AllowedEncryptionStatusesValueListEntryValuesEnum:

Fields:
  allowedDeviceManagementLevels: Allowed device management levels, an empty
    list allows all management levels.
  allowedEncryptionStatuses: Allowed encryptions statuses, an empty list
    allows all statuses.
  osConstraints: Allowed OS versions, an empty list allows all types and all
    versions.
  requireAdminApproval: Whether the device needs to be approved by the
    customer admin.
  requireCorpOwned: Whether the device needs to be corp owned.
  requireScreenlock: Whether or not screenlock is required for the
    DevicePolicy to be true. Defaults to `false`.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	fGoogleIdentityAccesscontextmanagerV1DevicePolicy.AllowedDeviceManagementLevelsValueListEntryValuesEnumi  zAllowedDeviceManagementLevelsValueListEntryValuesEnum enum type.

Values:
  MANAGEMENT_UNSPECIFIED: <no description>
  NONE: <no description>
  BASIC: <no description>
  COMPLETE: <no description>
r   r   r   r   r   N)
r   r   r    r!   r"   MANAGEMENT_UNSPECIFIEDNONEBASICCOMPLETEr1   r   r2   r3   5AllowedDeviceManagementLevelsValueListEntryValuesEnumr     s     DEHr2   r   c                   (    \ rS rSrSrSrSrSrSrSr	g)	bGoogleIdentityAccesscontextmanagerV1DevicePolicy.AllowedEncryptionStatusesValueListEntryValuesEnumi  zAllowedEncryptionStatusesValueListEntryValuesEnum enum type.

Values:
  ENCRYPTION_UNSPECIFIED: <no description>
  ENCRYPTION_UNSUPPORTED: <no description>
  UNENCRYPTED: <no description>
  ENCRYPTED: <no description>
r   r   r   r   r   N)
r   r   r    r!   r"   ENCRYPTION_UNSPECIFIEDENCRYPTION_UNSUPPORTEDUNENCRYPTED	ENCRYPTEDr1   r   r2   r3   1AllowedEncryptionStatusesValueListEntryValuesEnumr     s     KIr2   r   r   Tr   r   0GoogleIdentityAccesscontextmanagerV1OsConstraintr   r   r   r   r   N)r   r   r    r!   r"   r#   rD   r   r   rF   allowedDeviceManagementLevelsallowedEncryptionStatusesr$   osConstraintsro   requireAdminApprovalrequireCorpOwnedrequireScreenlockr1   r   r2   r3   r   r     s    8inn )..  #,"5"56mop{  #A'112eghswx(()[]^imn-"//2++A.,,Q/r2   r   c                       \ rS rSrSr " S S\R                  5      r\R                  " S5      r	\R                  " SS5      r\R                  " S5      rSrg	)
r   i  a  A restriction on the OS type and version of devices making requests.

Enums:
  OsTypeValueValuesEnum: Required. The allowed OS type.

Fields:
  minimumVersion: The minimum allowed OS version. If not set, any version of
    this OS satisfies the constraint. Format: `"major.minor.patch"`.
    Examples: `"10.5.301"`, `"9.2.1"`.
  osType: Required. The allowed OS type.
  requireVerifiedChromeOs: Only allows requests from devices with a verified
    Chrome OS. Verifications includes requirements that the device is
    enterprise-managed, conformant to domain policies, and the caller has
    permission to call the API targeted by the request.
c                   4    \ rS rSrSrSrSrSrSrSr	Sr
S	rS
rg)FGoogleIdentityAccesscontextmanagerV1OsConstraint.OsTypeValueValuesEnumi  a  Required. The allowed OS type.

Values:
  OS_UNSPECIFIED: The operating system of the device is not specified or
    not known.
  DESKTOP_MAC: A desktop Mac operating system.
  DESKTOP_WINDOWS: A desktop Windows operating system.
  DESKTOP_LINUX: A desktop Linux operating system.
  DESKTOP_CHROME_OS: A desktop ChromeOS operating system.
  ANDROID: An Android operating system.
  IOS: An iOS operating system.
r   r   r   r   r   r   r   r   N)r   r   r    r!   r"   OS_UNSPECIFIEDDESKTOP_MACDESKTOP_WINDOWSDESKTOP_LINUXDESKTOP_CHROME_OSANDROIDIOSr1   r   r2   r3   OsTypeValueValuesEnumr     s-     NKOMG
Cr2   r   r   r   r   r   N)r   r   r    r!   r"   r#   rD   r   r'   minimumVersionrF   osTypero   requireVerifiedChromeOsr1   r   r2   r3   r   r     sM     inn * ((+.6:&%2215r2   r   c                   D   \ rS rSrSr " S S\R                  5      r\R                  " S5      r	\R                  " S5      r
\R                  " SS5      r\R                  " SS	5      r\R                  " SS
5      r\R                  " S5      r\R"                  " S5      rSrg)r   i  a  `ServicePerimeter` describes a set of Google Cloud resources which can
freely import and export data amongst themselves, but not export outside of
the `ServicePerimeter`. If a request with a source within this
`ServicePerimeter` has a target outside of the `ServicePerimeter`, the
request will be blocked. Otherwise the request is allowed. There are two
types of Service Perimeter - Regular and Bridge. Regular Service Perimeters
cannot overlap, a single Google Cloud project can only belong to a single
regular Service Perimeter. Service Perimeter Bridges can contain only Google
Cloud projects as members, a single Google Cloud project may belong to
multiple Service Perimeter Bridges.

Enums:
  PerimeterTypeValueValuesEnum: Perimeter type indicator. A single project
    is allowed to be a member of single regular perimeter, but multiple
    service perimeter bridges. A project cannot be a included in a perimeter
    bridge without being included in regular perimeter. For perimeter
    bridges, the restricted service list as well as access level lists must
    be empty.

Fields:
  description: Description of the `ServicePerimeter` and its use. Does not
    affect behavior.
  name: Required. Resource name for the ServicePerimeter.  The `short_name`
    component must begin with a letter and only include alphanumeric and
    '_'. Format: `accessPolicies/{policy_id}/servicePerimeters/{short_name}`
  perimeterType: Perimeter type indicator. A single project is allowed to be
    a member of single regular perimeter, but multiple service perimeter
    bridges. A project cannot be a included in a perimeter bridge without
    being included in regular perimeter. For perimeter bridges, the
    restricted service list as well as access level lists must be empty.
  spec: Proposed (or dry run) ServicePerimeter configuration. This
    configuration allows to specify and test ServicePerimeter configuration
    without enforcing actual access restrictions. Only allowed to be set
    when the "use_explicit_dry_run_spec" flag is set.
  status: Current ServicePerimeter configuration. Specifies sets of
    resources, restricted services and access levels that determine
    perimeter content and boundaries.
  title: Human readable title. Must be unique within the Policy.
  useExplicitDryRunSpec: Use explicit dry run spec flag. Ordinarily, a dry-
    run spec implicitly exists  for all Service Perimeters, and that spec is
    identical to the status for those Service Perimeters. When this flag is
    set, it inhibits the generation of the implicit spec, thereby allowing
    the user to explicitly provide a configuration ("spec") to use in a dry-
    run version of the Service Perimeter. This allows the user to test
    changes to the enforced config ("status") without actually enforcing
    them. This testing is done through analyzing the differences between
    currently enforced and suggested restrictions. use_explicit_dry_run_spec
    must bet set to True if any of the fields in the spec are set to non-
    default values.
c                        \ rS rSrSrSrSrSrg)QGoogleIdentityAccesscontextmanagerV1ServicePerimeter.PerimeterTypeValueValuesEnumi*  a  Perimeter type indicator. A single project is allowed to be a member
of single regular perimeter, but multiple service perimeter bridges. A
project cannot be a included in a perimeter bridge without being included
in regular perimeter. For perimeter bridges, the restricted service list
as well as access level lists must be empty.

Values:
  PERIMETER_TYPE_REGULAR: Regular Perimeter.
  PERIMETER_TYPE_BRIDGE: Perimeter Bridge.
r   r   r   N)r   r   r    r!   r"   PERIMETER_TYPE_REGULARPERIMETER_TYPE_BRIDGEr1   r   r2   r3   PerimeterTypeValueValuesEnumr   *  s    	 r2   r   r   r   r   :GoogleIdentityAccesscontextmanagerV1ServicePerimeterConfigr   r   r   r   r   N)r   r   r    r!   r"   r#   rD   r   r'   ri   r-   rF   perimeterTyper$   specstatusrl   ro   useExplicitDryRunSpecr1   r   r2   r3   r   r     s    1fY^^  %%a(+			q	!$%%&DaH-			 \^_	`$!!"^`ab&



"%#003r2   r   c                       \ rS rSrSr\R                  " SSS9r\R                  " SSS9r\R                  " SSS9r	\R                  " SS	5      rS
rg)r   iA  a  `ServicePerimeterConfig` specifies a set of Google Cloud resources that
describe specific Service Perimeter configuration.

Fields:
  accessLevels: A list of `AccessLevel` resource names that allow resources
    within the `ServicePerimeter` to be accessed from the internet.
    `AccessLevels` listed must be in the same policy as this
    `ServicePerimeter`. Referencing a nonexistent `AccessLevel` is a syntax
    error. If no `AccessLevel` names are listed, resources within the
    perimeter can only be accessed via Google Cloud calls with request
    origins within the perimeter. Example:
    `"accessPolicies/MY_POLICY/accessLevels/MY_LEVEL"`. For Service
    Perimeter Bridge, must be empty.
  resources: A list of Google Cloud resources that are inside of the service
    perimeter. Currently only projects are allowed. Format:
    `projects/{project_number}`
  restrictedServices: Google Cloud services that are subject to the Service
    Perimeter restrictions. For example, if `storage.googleapis.com` is
    specified, access to the storage buckets inside the perimeter must meet
    the perimeter's access restrictions.
  vpcAccessibleServices: Configuration for APIs allowed within Perimeter.
r   Tr   r   r   9GoogleIdentityAccesscontextmanagerV1VpcAccessibleServicesr   r   N)r   r   r    r!   r"   r#   r'   accessLevels	resourcesrestrictedServicesr$   vpcAccessibleServicesr1   r   r2   r3   r   r   A  sU    . &&q48,##A5) ,,Q>#001lnopr2   r   c                   ^    \ rS rSrSr\R                  " SSS9r\R                  " S5      r	Sr
g)	r   i_  a^  Specifies how APIs are allowed to communicate within the Service
Perimeter.

Fields:
  allowedServices: The list of APIs usable within the Service Perimeter.
    Must be empty unless 'enable_restriction' is True.
  enableRestriction: Whether to restrict API calls within the Service
    Perimeter to the list of APIs specified in 'allowed_services'.
r   Tr   r   r   N)r   r   r    r!   r"   r#   r'   allowedServicesro   enableRestrictionr1   r   r2   r3   r   r   _  s,     ))!d;/,,Q/r2   r   c                       \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	\R                  " S5      r
S	rg
)ListAssetsResponsein  zListAssets response.

Fields:
  assets: Assets.
  nextPageToken: Token to retrieve the next page of results. Set to empty if
    there are no remaining results.
  readTime: Time the snapshot was taken.
r	   r   Tr   r   r   r   N)r   r   r    r!   r"   r#   r$   assetsr'   nextPageTokenrg   r1   r   r2   r3   r   r   n  s=     !!'1t<&''*-""1%(r2   r   c                       \ rS rSrSr\R                  " SSSS9r\R                  " SSSS9r\R                  " S	5      r
\R                  " S
\R                  R                  S9rSrg)r   i}  a  An Identity and Access Management (IAM) policy, which specifies access
controls for Google Cloud resources.   A `Policy` is a collection of
`bindings`. A `binding` binds one or more `members` to a single `role`.
Members can be user accounts, service accounts, Google groups, and domains
(such as G Suite). A `role` is a named list of permissions; each `role` can
be an IAM predefined role or a user-created custom role.  For some types of
Google Cloud resources, a `binding` can also specify a `condition`, which is
a logical expression that allows access to a resource only if the expression
evaluates to `true`. A condition can add constraints based on attributes of
the request, the resource, or both. To learn which resources support
conditions in their IAM policies, see the [IAM
documentation](https://cloud.google.com/iam/help/conditions/resource-
policies).  **JSON example:**      {       "bindings": [         {
"role": "roles/resourcemanager.organizationAdmin",           "members": [
"user:mike@example.com",             "group:admins@example.com",
"domain:google.com",             "serviceAccount:my-project-
id@appspot.gserviceaccount.com"           ]         },         {
"role": "roles/resourcemanager.organizationViewer",           "members": [
"user:eve@example.com"           ],           "condition": {
"title": "expirable access",             "description": "Does not grant
access after Sep 2020",             "expression": "request.time <
timestamp('2020-10-01T00:00:00.000Z')",           }         }       ],
"etag": "BwWWja0YfJA=",       "version": 3     }  **YAML example:**
bindings:     - members:       - user:mike@example.com       -
group:admins@example.com       - domain:google.com       -
serviceAccount:my-project-id@appspot.gserviceaccount.com       role:
roles/resourcemanager.organizationAdmin     - members:       -
user:eve@example.com       role: roles/resourcemanager.organizationViewer
condition:         title: expirable access         description: Does not
grant access after Sep 2020         expression: request.time <
timestamp('2020-10-01T00:00:00.000Z')     - etag: BwWWja0YfJA=     -
version: 3  For a description of IAM and its features, see the [IAM
documentation](https://cloud.google.com/iam/docs/).

Fields:
  auditConfigs: Specifies cloud audit logging configuration for this policy.
  bindings: Associates a list of `members` to a `role`. Optionally, may
    specify a `condition` that determines how and when the `bindings` are
    applied. Each of the `bindings` must contain at least one member.
  etag: `etag` is used for optimistic concurrency control as a way to help
    prevent simultaneous updates of a policy from overwriting each other. It
    is strongly suggested that systems make use of the `etag` in the read-
    modify-write cycle to perform policy updates in order to avoid race
    conditions: An `etag` is returned in the response to `getIamPolicy`, and
    systems are expected to put that etag in the request to `setIamPolicy`
    to ensure that their change will be applied to the same version of the
    policy.  **Important:** If you use IAM Conditions, you must include the
    `etag` field whenever you call `setIamPolicy`. If you omit this field,
    then IAM allows you to overwrite a version `3` policy with a version `1`
    policy, and all of the conditions in the version `3` policy are lost.
  version: Specifies the format of the policy.  Valid values are `0`, `1`,
    and `3`. Requests that specify an invalid value are rejected.  Any
    operation that affects conditional role bindings must specify version
    `3`. This requirement applies to the following operations:  * Getting a
    policy that includes a conditional role binding * Adding a conditional
    role binding to a policy * Changing a conditional role binding in a
    policy * Removing any role binding, with or without a condition, from a
    policy   that includes conditions  **Important:** If you use IAM
    Conditions, you must include the `etag` field whenever you call
    `setIamPolicy`. If you omit this field, then IAM allows you to overwrite
    a version `3` policy with a version `1` policy, and all of the
    conditions in the version `3` policy are lost.  If a policy does not
    include any conditions, operations on that policy may specify any valid
    version or leave the field unset.  To learn which resources support
    conditions in their IAM policies, see the [IAM
    documentation](https://cloud.google.com/iam/help/conditions/resource-
    policies).
r5   r   Tr   rI   r   r   r   r\   r   N)r   r   r    r!   r"   r#   r$   auditConfigsbindingsr+   r   ra   rb   rc   r   r1   r   r2   r3   r   r   }  sa    CJ ''q4H,##Iq4@(			a	 $""1i.?.?.E.EF'r2   r   c                      \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " S5       " S S\R                  5      5       r
\R                  " SS5      r\R                  " S	5      r\R                  " S
5      r\R                  " SS5      r\R                  " S5      r\R                  " S5      r\R                  " S5      rSrg)r   i  a,  A representation of a Google Cloud resource.

Messages:
  DataValue: The content of the resource, in which some sensitive fields are
    removed and may not be present.
  InternalDataValue: The actual metadata content for the resource, only
    visible for internal users.

Fields:
  data: The content of the resource, in which some sensitive fields are
    removed and may not be present.
  discoveryDocumentUri: The URL of the discovery document containing the
    resource's JSON schema. Example:
    `https://www.googleapis.com/discovery/v1/apis/compute/v1/rest`  This
    value is unspecified for resources that do not have an API based on a
    discovery document, such as Cloud Bigtable.
  discoveryName: The JSON schema name listed in the discovery document.
    Example: `Project`  This value is unspecified for resources that do not
    have an API based on a discovery document, such as Cloud Bigtable.
  internalData: The actual metadata content for the resource, only visible
    for internal users.
  parent: The full name of the immediate parent of this resource. See
    [Resource Names](https://cloud.google.com/apis/design/resource_names#ful
    l_resource_name) for more information.  For Google Cloud assets, this
    value is the parent resource defined in the [Cloud IAM policy
    hierarchy](https://cloud.google.com/iam/docs/overview#policy_hierarchy).
    Example: `//cloudresourcemanager.googleapis.com/projects/my_project_123`
    For third-party assets, this field may be set differently.
  resourceUrl: The REST URL for accessing the resource. An HTTP `GET`
    request using this URL returns the resource itself. Example:
    `https://cloudresourcemanager.googleapis.com/v1/projects/my-project-123`
    This value is unspecified for resources without a REST API.
  version: The API version. Example: "v1".
additionalPropertiesc                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
Resource.DataValuei  zThe content of the resource, in which some sensitive fields are
removed and may not be present.

Messages:
  AdditionalProperty: An additional property for a DataValue object.

Fields:
  additionalProperties: Properties of the object.
c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)%Resource.DataValue.AdditionalPropertyi  zAn additional property for a DataValue object.

Fields:
  key: Name of the additional property.
  value: A extra_types.JsonValue attribute.
r   extra_types.JsonValuer   r   Nr   r   r    r!   r"   r#   r'   keyr$   valuer1   r   r2   r3   AdditionalPropertyr     ,    
 !!!$c$$%<a@er2   r   r   Tr   r   Nr   r   r    r!   r"   r#   Messager   r$   r   r1   r   r2   r3   	DataValuer     s4    	AY.. 	A %112FTXYr2   r   c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
Resource.InternalDataValuei  a  The actual metadata content for the resource, only visible for
internal users.

Messages:
  AdditionalProperty: An additional property for a InternalDataValue
    object.

Fields:
  additionalProperties: Properties of the object. Contains field @type
    with type URL.
c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)-Resource.InternalDataValue.AdditionalPropertyi  zAn additional property for a InternalDataValue object.

Fields:
  key: Name of the additional property.
  value: A extra_types.JsonValue attribute.
r   r   r   r   Nr   r   r2   r3   r   r     r   r2   r   r   Tr   r   Nr   r   r2   r3   InternalDataValuer     s4    
	AY.. 	A %112FTXYr2   r   r   r   r   r   r   r   r   r   N)r   r   r    r!   r"   r   MapUnrecognizedFieldsr#   r   r   r   r$   datar'   discoveryDocumentUridiscoveryNameinternalDatarf   resourceUrlr   r1   r   r2   r3   r   r     s    !F !!"89Z)## Z :Z0 !!"89Z)++ Z :Z4 
		Q	/$"..q1''*-''(;Q?,  #&%%a(+!!!$'r2   r   c                      \ rS rSrSr " S S\R                  5      r " S S\R                  5      r\R                  " SS5      r
\R                  " S5      r\R                  " SS	S
S9r\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                  " S5      r\R$                  " SSS9r\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                  " S5      rSrg)StandardQueryParametersi*  a  Query parameters accepted by all methods.

Enums:
  FXgafvValueValuesEnum: V1 error format.
  AltValueValuesEnum: Data format for response.

Fields:
  f__xgafv: V1 error format.
  access_token: OAuth access token.
  alt: Data format for response.
  callback: JSONP
  fields: Selector specifying which fields to include in a partial response.
  key: API key. Your API key identifies your project and provides you with
    API access, quota, and reports. Required unless you provide an OAuth 2.0
    token.
  oauth_token: OAuth 2.0 token for the current user.
  prettyPrint: Returns response with indentations and line breaks.
  quotaUser: Available to use for quota purposes for server-side
    applications. Can be any arbitrary string assigned to a user, but should
    not exceed 40 characters.
  trace: A tracing token of the form "token:<tokenid>" to include in api
    requests.
  uploadType: Legacy upload protocol for media (e.g. "media", "multipart").
  upload_protocol: Upload protocol for media (e.g. "raw", "multipart").
c                   $    \ rS rSrSrSrSrSrSrg)*StandardQueryParameters.AltValueValuesEnumiE  zData format for response.

Values:
  json: Responses with Content-Type of application/json
  media: Media download with context-dependent Content-Type
  proto: Responses with Content-Type of application/x-protobuf
r   r   r   r   N)	r   r   r    r!   r"   jsonmediaprotor1   r   r2   r3   AltValueValuesEnumr   E  s     DEEr2   r   c                        \ rS rSrSrSrSrSrg)-StandardQueryParameters.FXgafvValueValuesEnumiQ  zFV1 error format.

Values:
  _1: v1 error format
  _2: v2 error format
r   r   r   N)r   r   r    r!   r"   _1_2r1   r   r2   r3   FXgafvValueValuesEnumr  Q  s     
B	
Br2   r  r   r   r   r   )defaultr   r   r   r   r   Tr   r         r   N)r   r   r    r!   r"   r#   rD   r   r  rF   f__xgafvr'   access_tokenaltcallbackfieldsr   oauth_tokenro   prettyPrint	quotaUsertrace
uploadTypeupload_protocolr1   r   r2   r3   r   r   *  s    4
9>> 
inn    !8!<(&&q),0!VD#""1%(  #&a #%%a(+&&q$7+##A&)



#%$$R(*))"-/r2   r   r	  z$.xgafvr  1r  2N)&r"   
__future__r   apitools.base.protorpcliter   r#   apitools.base.pyr   r   packager   r	   r5   r7   rI   rP   rK   rn   rr   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   AddCustomJsonFieldMappingAddCustomJsonEnumMappingr  r   r2   r3   <module>r     sA   ' < % ( <hI <h~%)## %B =Y&&  =F1"i 1"h8&)"3"3 8&v!#9 !#H"')*;*; "'Jt,y'8'8 t,n%G9#4#4 %GP9+<+< #i6G6G #0#y7H7H #4%iY5F5F %iP'AI4E4E 'AT	+i6G6G 	+>0y7H7H >0B(6y7H7H (6VH49;L;L H4VqARAR q<0	@Q@Q 0&** &IGY IGX^%y   ^%B<.i// <.~ 	 " "Z4  ! !114>  ! !114>r2   