
    ,]                    B'   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" " S7 S8\R                  5      r# " S9 S:\R                  5      r$ " S; S<\R                  5      r% " S= S>\R                  5      r& " S? S@\R                  5      r' " SA SB\R                  5      r( " SC SD\R                  5      r) " SE SF\R                  5      r* " SG SH\R                  5      r+ " SI SJ\R                  5      r, " SK SL\R                  5      r- " SM SN\R                  5      r. " SO SP\R                  5      r/ " SQ SR\R                  5      r0 " SS ST\R                  5      r1 " SU SV\R                  5      r2 " SW SX\R                  5      r3 " SY SZ\R                  5      r4 " S[ S\\R                  5      r5 " S] S^\R                  5      r6 " S_ S`\R                  5      r7 " Sa Sb\R                  5      r8 " Sc Sd\R                  5      r9 " Se Sf\R                  5      r: " Sg Sh\R                  5      r; " Si Sj\R                  5      r< " Sk Sl\R                  5      r= " Sm Sn\R                  5      r> " So Sp\R                  5      r? " Sq Sr\R                  5      r@ " Ss St\R                  5      rA " Su Sv\R                  5      rB " Sw Sx\R                  5      rC " Sy Sz\R                  5      rD " S{ S|\R                  5      rE " S} S~\R                  5      rF " S S\R                  5      rG " S S\R                  5      rH " S S\R                  5      rI " S S\R                  5      rJ " S S\R                  5      rK " S S\R                  5      rL " S S\R                  5      rM " S S\R                  5      rN " S S\R                  5      rO " S S\R                  5      rP " S S\R                  5      rQ " S S\R                  5      rR " S S\R                  5      rS " S S\R                  5      rT " S S\R                  5      rU " S S\R                  5      rV " S S\R                  5      rW " S S\R                  5      rX " S S\R                  5      rY " S S\R                  5      rZ " 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      ra " S S\R                  5      rb " S S\R                  5      rc " S S\R                  5      rd " S S\R                  5      re " S S\R                  5      rf " S S\R                  5      rg " S S\R                  5      rh " S S\R                  5      ri " S S\R                  5      rj " S S\R                  5      rk " S S\R                  5      rl " S S\R                  5      rm " S S\R                  5      rn " S S\R                  5      ro " S S\R                  5      rp " S S\R                  5      rq " S S\R                  5      rr " S S\R                  5      rs " S S\R                  5      rt " S S\R                  5      ru " S S\R                  5      rv " S S\R                  5      rw " S S\R                  5      rx " S S\R                  5      ry " S S\R                  5      rz " 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 GS \R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS	 GS
\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS \R                  5      r " GS! GS"\R                  5      r " GS# GS$\R                  5      r " GS% GS&\R                  5      r " GS' GS(\R                  5      r " GS) GS*\R                  5      r " GS+ GS,\R                  5      r " GS- GS.\R                  5      r " GS/ GS0\R                  5      r " GS1 GS2\R                  5      r " GS3 GS4\R                  5      r " GS5 GS6\R                  5      r " GS7 GS8\R                  5      r " GS9 GS:\R                  5      r " GS; GS<\R                  5      r " GS= GS>\R                  5      r " GS? GS@\R                  5      r " GSA GSB\R                  5      r " GSC GSD\R                  5      r " GSE GSF\R                  5      r " GSG GSH\R                  5      r " GSI GSJ\R                  5      r " GSK GSL\R                  5      r " GSM GSN\R                  5      r " GSO GSP\R                  5      r " GSQ GSR\R                  5      r " GSS GST\R                  5      r " GSU GSV\R                  5      r " GSW GSX\R                  5      r " GSY GSZ\R                  5      r " GS[ GS\\R                  5      r " GS] GS^\R                  5      r " GS_ GS`\R                  5      r " GSa GSb\R                  5      r " GSc GSd\R                  5      r " GSe GSf\R                  5      r " GSg GSh\R                  5      r " GSi GSj\R                  5      r " GSk GSl\R                  5      r " GSm GSn\R                  5      r " GSo GSp\R                  5      r " GSq GSr\R                  5      r " GSs GSt\R                  5      r " GSu GSv\R                  5      r " GSw GSx\R                  5      r " GSy GSz\R                  5      r " GS{ GS|\R                  5      r " GS} GS~\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r " GS GS\R                  5      r\GR                  " \GSGS5        \GR                  " \GR                  GSGS5        \GR                  " \GR                  GSGS5        \GR                  " \9GSGS5        \GR                  " \%GSGS5        \GR                  " \%GSGS5        \GR                  " \%GSGS5        \GR                  " \%GSGS5        \GR                  " \%GSGS5        \GR                  " \%GSGS5        \GR                  " \%GSGS5        \GR                  " \%GSGS5        \GR                  " \%GSGS5        \GR                  " \%GSGS5        \GR                  " \%GSGS5        \GR                  " \%GSGS5        \GR                  " \+GSGS5        \GR                  " \+GSGS5        Gg(  zGenerated message classes for cloudasset version v1.

The Cloud Asset API manages the history and inventory of Google Cloud
resources.
    )absolute_import)messages)encoding)extra_types
cloudassetc                   <    \ rS rSrSr\R                  " S5      rSrg)
AWSDetails   a  Additional information for an asset fetched from AWS

Fields:
  awsAccount: The AWS Account in [ARN format]
    (https://docs.aws.amazon.com/service-authorization/latest/reference/list
    _awsaccountmanagement.html#awsaccountmanagement-resources-for-iam-
    policies)
    N)	__name__
__module____qualname____firstlineno____doc__	_messagesStringField
awsAccount__static_attributes__r       Qlib/googlecloudsdk/generated_clients/apis/cloudasset/v1/cloudasset_v1_messages.pyr	   r	      s     $$Q'*r   r	   c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " SSS9r	\R                  " S5      r
S	rg
)AWSInfo   a7  Additional information for an asset fetched from AWS

Fields:
  awsAccount: The AWS Account in [ARN format]
    (https://docs.aws.amazon.com/service-authorization/latest/reference/list
    _awsaccountmanagement.html#awsaccountmanagement-resources-for-iam-
    policies)
  organization: The ARN of the AWS Organization this asset belongs to, empty
    if no AWS organization exists. (https://docs.aws.amazon.com/cli/latest/r
    eference/organizations/describe-organization.html) E.g.: "Organization":
    "arn:aws:organizations::111111111111:organization/o-exampleorgid"
  organizationalUnit: The AWS Organizational Units (OUs) this asset belongs
    to, starting from closest OU to furthest OU, empty if no OUs exist.
    (https://docs.aws.amazon.com/cli/latest/reference/organizations/list-
    organizational-units-for-parent.html) E.g.: "OrganizationalUnits": [
    "arn:aws:organizations::o-exampleorgid:ou/r-examplerootid111/ou-
    examplerootid111-exampleouid111"
    "arn:aws:organizations::o-exampleorgid:ou/r-examplerootid111/ou-
    examplerootid111-exampleouid222" ]
  root: The AWS Root this asset belongs to, empty if no root exists.
    (https://docs.aws.amazon.com/cli/latest/reference/organizations/list-
    roots.html) E.g.: "Root": "arn:aws:organizations::111111111111:root/o-
    exampleorgid/r-examplerootid111"
r         Trepeated   r   N)r   r   r   r   r   r   r   r   organizationorganizationalUnitrootr   r   r   r   r   r      sL    2 $$Q'*&&q), ,,Q>			q	!$r   r   c                   \    \ rS rSrSr\R                  " SSS9r\R                  " SSS9rSr	g)	AccessSelector?   a  Specifies roles and/or permissions to analyze, to determine both the
identities possessing them and the resources they control. If multiple
values are specified, results will include roles or permissions matching any
of them. The total number of roles and permissions should be equal or less
than 10.

Fields:
  permissions: Optional. The permissions to appear in result.
  roles: Optional. The roles to appear in result.
r   Tr   r   r   N)
r   r   r   r   r   r   r   permissionsrolesr   r   r   r   r$   r$   ?   s-    	 %%a$7+


D
1%r   r$   c                       \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	\R                  " S\R                  R                  S	9rS
rg)AdditionalInfoO   aM  The proto to hold the detailed information about the validation result.

Fields:
  invalidAccount: Optional. The invalid Collector accounts. This field will
    be set only when the connection state is AWS_INVALID_COLLECTOR_ACCOUNTS.
  summary: Required. The summary of the validation result. For AWS, when the
    connection does not pass the Delegated Role validation, including
    Delegated Role assumption and listing accounts when auto-discovery is
    enabled, it will contain the detailed failure reasons. If the Delegated
    Role validation passes, this field will be in the format of
    "$VALIDATED_COLLECTOR_ACCT_CNT out of $TOTAL_COLLECTOR_ACCT_CNT
    Collector accounts were validated. The valid Collector accounts rate is
    $PERCENTAGE." For Azure, when the status is
    AZURE_FAILED_TO_ASSUME_MANAGED_IDENTITY, it will contain the detailed
    failure reasons. When the status is
    AZURE_MANAGED_IDENTITY_MISSING_REQUIRED_PERMISSION, it will contain the
    missing required permissions.
  validAccountCnt: Required. The number of valid AWS accounts or Azure
    subscriptions.
InvalidCollectorAccountr   Tr   r   r   variantr   N)r   r   r   r   r   r   MessageFieldinvalidAccountr   summaryIntegerFieldVariantINT32validAccountCntr   r   r   r   r)   r)   O   sM    * ))*CQQUV.!!!$'**1i6G6G6M6MN/r   r)   c                   <    \ rS rSrSr\R                  " S5      rSrg)#AnalyzeIamPolicyLongrunningMetadataj   zRepresents the metadata of the longrunning operation for the
AnalyzeIamPolicyLongrunning RPC.

Fields:
  createTime: Output only. The time the operation was created.
r   r   N)	r   r   r   r   r   r   r   
createTimer   r   r   r   r6   r6   j   s     $$Q'*r   r6   c                       \ rS rSrSr\R                  " SS5      r\R                  " SS5      r\R                  " S5      r
Srg	)
"AnalyzeIamPolicyLongrunningRequestu   a  A request message for AssetService.AnalyzeIamPolicyLongrunning.

Fields:
  analysisQuery: Required. The request query.
  outputConfig: Required. Output configuration indicating where the results
    will be output to.
  savedAnalysisQuery: Optional. The name of a saved query, which must be in
    the format of: * projects/project_number/savedQueries/saved_query_id *
    folders/folder_number/savedQueries/saved_query_id *
    organizations/organization_number/savedQueries/saved_query_id If both
    `analysis_query` and `saved_analysis_query` are provided, they will be
    merged together with the `saved_analysis_query` as base and the
    `analysis_query` as overrides. For more details of the merge behavior,
    refer to the [MergeFrom](https://developers.google.com/protocol-buffers/
    docs/reference/cpp/google.protobuf.message#Message.MergeFrom.details)
    doc. Note that you cannot override primitive fields with default value,
    such as 0 or empty string, etc., because we use proto3, which doesn't
    support field presence yet.
IamPolicyAnalysisQueryr   IamPolicyAnalysisOutputConfigr   r   r   N)r   r   r   r   r   r   r.   analysisQueryoutputConfigr   savedAnalysisQueryr   r   r   r   r:   r:   u   s@    ( (()A1E-''(GK, ,,Q/r   r:   c                       \ rS rSrSrSrg)#AnalyzeIamPolicyLongrunningResponse   z@A response message for AssetService.AnalyzeIamPolicyLongrunning.r   Nr   r   r   r   r   r   r   r   r   rB   rB      s    Ir   rB   c                       \ rS rSrSr\R                  " S5      r\R                  " SS5      r	\R                  " SSSS9r
S	rg
)AnalyzeIamPolicyResponse   a  A response message for AssetService.AnalyzeIamPolicy.

Fields:
  fullyExplored: Represents whether all entries in the main_analysis and
    service_account_impersonation_analysis have been fully explored to
    answer the query in the request.
  mainAnalysis: The main analysis that matches the original request.
  serviceAccountImpersonationAnalysis: The service account impersonation
    analysis if
    IamPolicyAnalysisQuery.Options.analyze_service_account_impersonation is
    enabled.
r   IamPolicyAnalysisr   r   Tr   r   N)r   r   r   r   r   r   BooleanFieldfullyExploredr.   mainAnalysis#serviceAccountImpersonationAnalysisr   r   r   r   rF   rF      sD     ((+-''(;Q?,(1(>(>?RTU`d(e%r   rF   c                   <    \ rS rSrSr\R                  " SSSS9rSrg)	AnalyzeMoveResponse   zThe response message for resource move analysis.

Fields:
  moveAnalysis: The list of analyses returned from performing the intended
    resource move analysis. The analysis is grouped by different Google
    Cloud services.
MoveAnalysisr   Tr   r   N)	r   r   r   r   r   r   r.   moveAnalysisr   r   r   r   rN   rN      s     ''DI,r   rN   c                       \ rS rSrSr\R                  " SS5      r\R                  " S5      r	\R                  " SSSS	9r
S
rg)AnalyzeOrgPoliciesResponse   a  The response message for AssetService.AnalyzeOrgPolicies.

Fields:
  constraint: The definition of the constraint in the request.
  nextPageToken: The page token to fetch the next page for
    AnalyzeOrgPoliciesResponse.org_policy_results.
  orgPolicyResults: The organization policies under the
    AnalyzeOrgPoliciesRequest.scope with the
    AnalyzeOrgPoliciesRequest.constraint.
AnalyzerOrgPolicyConstraintr   r   OrgPolicyResultr   Tr   r   N)r   r   r   r   r   r   r.   
constraintr   nextPageTokenorgPolicyResultsr   r   r   r   rS   rS      sB    	 %%&CQG*''*-++,=q4Pr   rS   c                       \ rS rSrSr\R                  " SS5      r\R                  " SSSS9r\R                  " S	5      r
S
rg)&AnalyzeOrgPolicyGovernedAssetsResponse   aA  The response message for AssetService.AnalyzeOrgPolicyGovernedAssets.

Fields:
  constraint: The definition of the constraint in the request.
  governedAssets: The list of the analyzed governed assets.
  nextPageToken: The page token to fetch the next page for
    AnalyzeOrgPolicyGovernedAssetsResponse.governed_assets.
rU   r   EGoogleCloudAssetV1AnalyzeOrgPolicyGovernedAssetsResponseGovernedAssetr   Tr   r   r   N)r   r   r   r   r   r   r.   rW   governedAssetsr   rX   r   r   r   r   r[   r[      sJ     %%&CQG*))*qst  @D  E.''*-r   r[   c                       \ rS rSrSr\R                  " SS5      r\R                  " SSSS9r\R                  " S	5      r
S
rg)*AnalyzeOrgPolicyGovernedContainersResponse   aU  The response message for
AssetService.AnalyzeOrgPolicyGovernedContainers.

Fields:
  constraint: The definition of the constraint in the request.
  governedContainers: The list of the analyzed governed containers.
  nextPageToken: The page token to fetch the next page for
    AnalyzeOrgPolicyGovernedContainersResponse.governed_containers.
rU   r   #GoogleCloudAssetV1GovernedContainerr   Tr   r   r   N)r   r   r   r   r   r   r.   rW   governedContainersr   rX   r   r   r   r   r`   r`      sD     %%&CQG* --.SUVaef''*-r   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\R                  " SSS	S
9rSrg)AnalyzerOrgPolicy   a  This organization policy message is a modified version of the one
defined in the Organization Policy system. This message contains several
fields defined in the original organization policy with some new fields for
analysis purpose.

Fields:
  appliedResource: The [full resource name] (https://cloud.google.com/asset-
    inventory/docs/resource-name-format) of an organization/folder/project
    resource where this organization policy applies to. For any user defined
    org policies, this field has the same value as the [attached_resource]
    field. Only for default policy, this field has the different value.
  attachedResource: The [full resource name]
    (https://cloud.google.com/asset-inventory/docs/resource-name-format) of
    an organization/folder/project resource where this organization policy
    is set. Notice that some type of constraints are defined with default
    policy. This field will be empty for them.
  inheritFromParent: If `inherit_from_parent` is true, Rules set higher up
    in the hierarchy (up to the closest root) are inherited and present in
    the effective policy. If it is false, then no rules are inherited, and
    this policy becomes the effective root for evaluation.
  reset: Ignores policies set above this resource and restores the default
    behavior of the constraint at this resource. This field can be set in
    policies for either list or boolean constraints. If set, `rules` must be
    empty and `inherit_from_parent` must be set to false.
  rules: List of rules for this organization policy.
r   r   r   r   GoogleCloudAssetV1Rule   Tr   r   N)r   r   r   r   r   r   r   appliedResourceattachedResourcerI   inheritFromParentresetr.   rulesr   r   r   r   re   re      s`    6 ))!,/**1-,,Q/

 
 
#%

 
 !91t
L%r   re   c                   d    \ rS rSrSr\R                  " SS5      r\R                  " SS5      rSr	g)	rU   i  zThe organization policy constraint definition.

Fields:
  customConstraint: The definition of the custom constraint.
  googleDefinedConstraint: The definition of the canned constraint defined
    by Google.
"GoogleCloudAssetV1CustomConstraintr   GoogleCloudAssetV1Constraintr   r   N)
r   r   r   r   r   r   r.   customConstraintgoogleDefinedConstraintr   r   r   r   rU   rU     s3     ++,PRST%223QSTUr   rU   c                   D   \ 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
SSS	9r\R                  " S5      r\R                  " SS5      r\R                  " S5      r\R                  " SSSS	9r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R                  " S5      rSrg )!Asseti  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. IAM policy), or a relationship (e.g. an
INSTANCE_TO_INSTANCEGROUP relationship). See [Supported asset
types](https://cloud.google.com/asset-inventory/docs/supported-asset-types)
for more information.

Fields:
  accessLevel: Also refer to the [access level user
    guide](https://cloud.google.com/access-context-
    manager/docs/overview#access-levels).
  accessPolicy: 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"]`
  assetExceptions: The exceptions of a resource.
  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 IAM policy set on a Google Cloud
    resource. There can be a maximum of one IAM policy set on any given
    resource. In addition, 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/help/allow-policies/inheritance) for
    more information.
  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.
  osInventory: A representation of runtime OS Inventory information. See
    [this topic](https://cloud.google.com/compute/docs/instances/os-
    inventory-management) for more information.
  otherCloudProperties: A OtherCloudProperties attribute.
  relatedAsset: One related asset of the current asset.
  relatedAssets: DEPRECATED. This field only presents for the purpose of
    backward-compatibility. The server will never generate responses with
    this field. The related assets of the asset of one relationship type.
    One asset only represents one type of relationship.
  resource: A representation of the resource.
  servicePerimeter: Also refer to the [service perimeter user
    guide](https://cloud.google.com/vpc-service-controls/docs/overview).
  updateTime: The last update timestamp of an asset. update_time is updated
    when create/update/delete operation is performed.
/GoogleIdentityAccesscontextmanagerV1AccessLevelr   0GoogleIdentityAccesscontextmanagerV1AccessPolicyr   r   Tr   AssetExceptionr   rh   Policy      GoogleCloudOrgpolicyV1Policy   	Inventory	   OtherCloudProperties
   RelatedAsset   RelatedAssets   Resource   4GoogleIdentityAccesscontextmanagerV1ServicePerimeter      r   N)r   r   r   r   r   r   r.   accessLevelaccessPolicyr   	ancestorsassetExceptions	assetType	iamPolicyname	orgPolicyosInventoryotherCloudPropertiesrelatedAssetrelatedAssetsresourceservicePerimeter
updateTimer   r   r   r   rt   rt     s"   :x &&'XZ[\+''(Z\]^,##A5)**+;QN/##A&)$$Xq1)			q	!$$$%CQQUV)&&{A6+"//0FK'';,(("=-##J3(++,bdfg$$R(*r   rt   c                   >    \ rS rSrSr\R                  " SS5      rSrg)AssetEnrichmenti`  zThe enhanced metadata information for a resource.

Fields:
  resourceOwners: The resource owners for a resource. Note that this field
    only contains the members that have "roles/owner" role in the resource's
    IAM Policy.
ResourceOwnersr   r   N)	r   r   r   r   r   r   r.   resourceOwnersr   r   r   r   r   r   `  s     ))*:A>.r   r   c                       \ rS rSrSr " S S\R                  5      r\R                  " S5      r	\R                  " SS5      rSrg)	rw   il  zAn exception of an asset.

Enums:
  ExceptionTypeValueValuesEnum: The type of exception.

Fields:
  details: The details of the exception.
  exceptionType: The type of exception.
c                        \ rS rSrSrSrSrSrg)+AssetException.ExceptionTypeValueValuesEnumiw  zThe type of exception.

Values:
  EXCEPTION_TYPE_UNSPECIFIED: exception_type is not applicable for the
    current asset.
  TRUNCATION: The asset content is truncated.
r   r   r   N)r   r   r   r   r   EXCEPTION_TYPE_UNSPECIFIED
TRUNCATIONr   r   r   r   ExceptionTypeValueValuesEnumr   w  s     "#Jr   r   r   r   r   N)r   r   r   r   r   r   Enumr   r   details	EnumFieldexceptionTyper   r   r   r   rw   rw   l  s<    	Y^^ 	 !!!$'%%&DaH-r   rw   c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
AttachedResourcei  aj  Attached resource representation, which is defined by the corresponding
service provider. It represents an attached resource's payload.

Fields:
  assetType: The type of this attached resource. Example:
    `osconfig.googleapis.com/Inventory` You can find the supported attached
    asset types of each resource in this table:
    `https://cloud.google.com/asset-inventory/docs/supported-asset-types`
  versionedResources: Versioned resource representations of this attached
    resource. This is repeated because there could be multiple versions of
    the attached resource representations during version migration.
r   VersionedResourcer   Tr   r   N)r   r   r   r   r   r   r   r   r.   versionedResourcesr   r   r   r   r   r     s/     ##A&) --.A1tTr   r   c                   `    \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	Sr
g	)
AuditConfigi  aw  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   servicer   r   r   r   r   r     s.    0 **+;QN/!!!$'r   r   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
)r   i  aR  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.LogTypeValueValuesEnumi  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_READr   r   r   r   LogTypeValueValuesEnumr     s     JJIr   r   r   Tr   r   r   N)r   r   r   r   r   r   r   r   r   exemptedMembersr   logTyper   r   r   r   r   r     s>    y~~  ))!d;/ 8!<'r   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S9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S5      r\R                  " S5      r\R                  " S5      rSrg)	AzureInfoi  a	  Additional information for an asset fetched from Azure

Fields:
  managementGroupDisplayNames: The Azure Management Group
    [displayName](https://learn.microsoft.com/en-
    us/rest/api/managementgroups/management-groups/list?view=rest-
    managementgroups-2020-05-01&tabs=HTTP#examples) Order is from leaf
    management group to the root management group, which corresponds to the
    order in management_group_resource_ids field. E.g.: Test Management
    Group
  managementGroupResourceIds: The Azure Management Group ID
    (https://learn.microsoft.com/en-us/rest/api/managementgroups/management-
    groups/list?view=rest-managementgroups-2020-05-01&tabs=HTTP#examples)
    Order is from leaf management group to the root management group E.g.:
    /providers/Microsoft.Management/managementGroups/group-name
  managementGroups: The Azure Management Group info Order is from leaf
    management group to the root management group
  resourceGroup: The Azure Resource Group info
  resourceGroupName: The Azure Resource Group
    [name](https://learn.microsoft.com/en-us/rest/api/resources/resource-
    groups/list?view=rest-resources-2021-04-01#resourcegroupproperties)
    E.g.: myResourceGroup
  resourceGroupResourceId: The Azure Resource Group ID
    (https://learn.microsoft.com/en-us/rest/api/resources/resource-
    groups/list?view=rest-resources-2021-04-01#resourcegroupproperties)
    E.g.: /subscriptions/1a11aad8-de27-1234-85e9-
    0f675821f15c/resourceGroups/group-name
  subscription: The Azure Subscription info
  subscriptionDisplayName: The Azure Subscription
    [displayName](https://learn.microsoft.com/en-
    us/rest/api/resources/subscriptions/list?view=rest-
    resources-2022-12-01&tabs=HTTP#examples) E.g.: My Test Subscription
  subscriptionResourceId: The Azure Subscription ID
    (https://learn.microsoft.com/en-
    us/rest/api/resources/subscriptions/list?view=rest-
    resources-2022-12-01&tabs=HTTP#examples) E.g.:
    /subscriptions/1a11aad8-de27-1234-85e9-0f675821f15c
  tenant: The Azure Tenant info
  tenantDisplayName: The Azure Tenant
    [displayName](https://learn.microsoft.com/en-
    us/rest/api/resources/tenants/list?view=rest-
    resources-2022-12-01&tabs=HTTP#examples) E.g.: Test_Display_Name
  tenantResourceId: The Azure Tenant ID (https://learn.microsoft.com/en-
    us/azure/azure-portal/get-subscription-tenant-id) E.g.:
    /tenants/a11aaa11-aa11-1aa1-11aa-1aaa11a
r   Tr   r   ManagementGroupInfor   ResourceGroupInfor   rh   ry   SubscriptionInforz   r|   r~   
TenantInfor   r   r   r   N)r   r   r   r   r   r   r   managementGroupDisplayNamesmanagementGroupResourceIdsr.   managementGroupsresourceGroupresourceGroupNameresourceGroupResourceIdsubscriptionsubscriptionDisplayNamesubscriptionResourceIdtenanttenantDisplayNametenantResourceIdr   r   r   r   r   r     s    -^ !* 5 5a$ G(44QF++,A1tT(()<a@-++A.%11!4''(:A>,%11!4$003!!,3&++B/**2.r   r   c                   <    \ rS rSrSr\R                  " SSSS9rSrg)	BatchGetAssetsHistoryResponsei  z`Batch get assets history response.

Fields:
  assets: A list of assets with valid time windows.
TemporalAssetr   Tr   r   N)	r   r   r   r   r   r   r.   assetsr   r   r   r   r   r     s     !!/1tD&r   r   c                   <    \ rS rSrSr\R                  " SSSS9rSrg)	$BatchGetEffectiveIamPoliciesResponsei  a  A response message for AssetService.BatchGetEffectiveIamPolicies.

Fields:
  policyResults: The effective policies for a batch of resources. Note that
    the results order is the same as the order of
    BatchGetEffectiveIamPoliciesRequest.names. When a resource does not have
    any effective IAM policies, its corresponding policy_result will contain
    empty EffectiveIamPolicy.policies.
EffectiveIamPolicyr   Tr   r   N)	r   r   r   r   r   r   r.   policyResultsr   r   r   r   r   r     s     (()=q4P-r   r   c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r	\R                  " SS5      r\R                  " S5      r\R                  " S5      rS	rg
)BigQueryDestinationi-  a  A BigQuery destination for exporting assets to.

Fields:
  dataset: Required. The BigQuery dataset in format
    "projects/projectId/datasets/datasetId", to which the snapshot result
    should be exported. If this dataset does not exist, the export call
    returns an INVALID_ARGUMENT error. Setting the `contentType` for
    `exportAssets` determines the [schema](/asset-inventory/docs/exporting-
    to-bigquery#bigquery-schema) of the BigQuery table. Setting
    `separateTablesPerAssetType` to `TRUE` also influences the schema.
  force: If the destination table already exists and this flag is `TRUE`,
    the table will be overwritten by the contents of assets snapshot. If the
    flag is `FALSE` or unset and the destination table already exists, the
    export call returns an INVALID_ARGUMENT error.
  partitionSpec: [partition_spec] determines whether to export to
    partitioned table(s) and how to partition the data. If [partition_spec]
    is unset or [partition_spec.partition_key] is unset or
    `PARTITION_KEY_UNSPECIFIED`, the snapshot results will be exported to
    non-partitioned table(s). [force] will decide whether to overwrite
    existing table(s). If [partition_spec] is specified. First, the snapshot
    results will be written to partitioned table(s) with two additional
    timestamp columns, readTime and requestTime, one of which will be the
    partition key. Secondly, in the case when any destination table already
    exists, it will first try to update existing table's schema as necessary
    by appending additional columns. Then, if [force] is `TRUE`, the
    corresponding partition will be overwritten by the snapshot results
    (data in different partitions will remain intact); if [force] is unset
    or `FALSE`, it will append the data. An error will be returned if the
    schema update or data appension fails.
  separateTablesPerAssetType: If this flag is `TRUE`, the snapshot results
    will be written to one or multiple tables, each of which contains
    results of one asset type. The [force] and [partition_spec] fields will
    apply to each of them. Field [table] will be concatenated with "_" and
    the asset type names (see https://cloud.google.com/asset-
    inventory/docs/supported-asset-types for supported asset types) to
    construct per-asset-type table names, in which all non-alphanumeric
    characters like "." and "/" will be substituted by "_". Example: if
    field [table] is "mytable" and snapshot results contain
    "storage.googleapis.com/Bucket" assets, the corresponding table name
    will be "mytable_storage_googleapis_com_Bucket". If any of these tables
    does not exist, a new table with the concatenated name will be created.
    When [content_type] in the ExportAssetsRequest is `RESOURCE`, the schema
    of each table will include RECORD-type columns mapped to the nested
    fields in the Asset.resource.data field of that asset type (up to the 15
    nested level BigQuery supports
    (https://cloud.google.com/bigquery/docs/nested-repeated#limitations)).
    The fields in >15 nested levels will be stored in JSON format string as
    a child column of its parent RECORD column. If error occurs when
    exporting to any table, the whole export call will return an error but
    the export results that already succeed will persist. Example: if
    exporting to table_type_A succeeds when exporting to table_type_B fails
    during one export call, the results in table_type_A will persist and
    there will not be partial results persisting in a table.
  table: Required. The BigQuery table to which the snapshot result should be
    written. If this table does not exist, a new table with the given name
    will be created.
r   r   PartitionSpecr   r   rh   r   N)r   r   r   r   r   r   r   datasetrI   forcer.   partitionSpecseparateTablesPerAssetTypetabler   r   r   r   r   r   -  s]    8t !!!$'

 
 
#%((!<-(55a8



"%r   r   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
)Bindingio  at  Associates `members`, or principals, 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 principals 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 principals requesting access for a Google Cloud
    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. Does not include identities that come from
    external identity providers (IdPs) through identity federation. *
    `user:{emailid}`: An email address that represents a specific Google
    account. For example, `alice@example.com` . *
    `serviceAccount:{emailid}`: An email address that represents a Google
    service account. For example, `my-other-
    app@appspot.gserviceaccount.com`. *
    `serviceAccount:{projectid}.svc.id.goog[{namespace}/{kubernetes-sa}]`:
    An identifier for a [Kubernetes service
    account](https://cloud.google.com/kubernetes-engine/docs/how-
    to/kubernetes-service-accounts). For example, `my-
    project.svc.id.goog[my-namespace/my-kubernetes-sa]`. *
    `group:{emailid}`: An email address that represents a Google group. For
    example, `admins@example.com`. * `domain:{domain}`: The G Suite domain
    (primary) that represents all the users of that domain. For example,
    `google.com` or `example.com`. * `principal://iam.googleapis.com/locatio
    ns/global/workforcePools/{pool_id}/subject/{subject_attribute_value}`: A
    single identity in a workforce identity pool. * `principalSet://iam.goog
    leapis.com/locations/global/workforcePools/{pool_id}/group/{group_id}`:
    All workforce identities in a group. * `principalSet://iam.googleapis.co
    m/locations/global/workforcePools/{pool_id}/attribute.{attribute_name}/{
    attribute_value}`: All workforce identities with a specific attribute
    value. * `principalSet://iam.googleapis.com/locations/global/workforcePo
    ols/{pool_id}/*`: All identities in a workforce identity pool. * `princi
    pal://iam.googleapis.com/projects/{project_number}/locations/global/work
    loadIdentityPools/{pool_id}/subject/{subject_attribute_value}`: A single
    identity in a workload identity pool. * `principalSet://iam.googleapis.c
    om/projects/{project_number}/locations/global/workloadIdentityPools/{poo
    l_id}/group/{group_id}`: A workload identity pool group. * `principalSet
    ://iam.googleapis.com/projects/{project_number}/locations/global/workloa
    dIdentityPools/{pool_id}/attribute.{attribute_name}/{attribute_value}`:
    All identities in a workload identity pool with a certain attribute. * `
    principalSet://iam.googleapis.com/projects/{project_number}/locations/gl
    obal/workloadIdentityPools/{pool_id}/*`: All identities in a workload
    identity pool. * `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. * `deleted:principal://iam.google
    apis.com/locations/global/workforcePools/{pool_id}/subject/{subject_attr
    ibute_value}`: Deleted single identity in a workforce identity pool. For
    example, `deleted:principal://iam.googleapis.com/locations/global/workfo
    rcePools/my-pool-id/subject/my-subject-attribute-value`.
  role: Role that is assigned to the list of `members`, or principals. For
    example, `roles/viewer`, `roles/editor`, or `roles/owner`. For an
    overview of the IAM roles and permissions, see the [IAM
    documentation](https://cloud.google.com/iam/docs/roles-overview). For a
    list of the available pre-defined roles, see
    [here](https://cloud.google.com/iam/docs/understanding-roles).
Exprr   r   Tr   r   r   N)r   r   r   r   r   r   r.   	conditionr   membersroler   r   r   r   r   r   o  s?    Ob $$VQ/)!!!d3'			q	!$r   r   c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
,CloudassetAnalyzeIamPolicyLongrunningRequesti  a~  A CloudassetAnalyzeIamPolicyLongrunningRequest object.

Fields:
  analyzeIamPolicyLongrunningRequest: A AnalyzeIamPolicyLongrunningRequest
    resource to be passed as the request body.
  scope: Required. The relative name of the root asset. Only resources and
    IAM policies within the scope will be analyzed. This can only be an
    organization number (such as "organizations/123"), a folder number (such
    as "folders/123"), a project ID (such as "projects/my-project-id"), or a
    project number (such as "projects/12345"). To know how to get
    organization ID, visit [here ](https://cloud.google.com/resource-
    manager/docs/creating-managing-
    organization#retrieving_your_organization_id). To know how to get folder
    or project ID, visit [here ](https://cloud.google.com/resource-
    manager/docs/creating-managing-
    folders#viewing_or_listing_folders_and_projects).
r:   r   r   Trequiredr   N)r   r   r   r   r   r   r.   "analyzeIamPolicyLongrunningRequestr   scoper   r   r   r   r   r     s0    $ (1'='=>bde'f$


D
1%r   r   c                   .   \ rS rSrSr\R                  " SSS9r\R                  " SSS9r\R                  " S5      r	\R                  " S5      r
\R                  " S	5      r\R                  " S
5      r\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                  " SSS9rSrg)!CloudassetAnalyzeIamPolicyRequesti  a  A CloudassetAnalyzeIamPolicyRequest object.

Fields:
  analysisQuery_accessSelector_permissions: Optional. The permissions to
    appear in result.
  analysisQuery_accessSelector_roles: Optional. The roles to appear in
    result.
  analysisQuery_conditionContext_accessTime: The hypothetical access
    timestamp to evaluate IAM conditions. Note that this value must not be
    earlier than the current time; otherwise, an INVALID_ARGUMENT error will
    be returned.
  analysisQuery_identitySelector_identity: Required. The identity appear in
    the form of principals in [IAM policy
    binding](https://cloud.google.com/iam/reference/rest/v1/Binding). The
    examples of supported forms are: "user:mike@example.com",
    "group:admins@example.com", "domain:google.com", "serviceAccount:my-
    project-id@appspot.gserviceaccount.com". Notice that wildcard characters
    (such as * and ?) are not supported. You must give a specific identity.
  analysisQuery_options_analyzeServiceAccountImpersonation: Optional. If
    true, the response will include access analysis from identities to
    resources via service account impersonation. This is a very expensive
    operation, because many derived queries will be executed. We highly
    recommend you use AssetService.AnalyzeIamPolicyLongrunning RPC instead.
    For example, if the request analyzes for which resources user A has
    permission P, and there's an IAM policy states user A has
    iam.serviceAccounts.getAccessToken permission to a service account SA,
    and there's another IAM policy states service account SA has permission
    P to a Google Cloud folder F, then user A potentially has access to the
    Google Cloud folder F. And those advanced analysis results will be
    included in
    AnalyzeIamPolicyResponse.service_account_impersonation_analysis. Another
    example, if the request analyzes for who has permission P to a Google
    Cloud folder F, and there's an IAM policy states user A has
    iam.serviceAccounts.actAs permission to a service account SA, and
    there's another IAM policy states service account SA has permission P to
    the Google Cloud folder F, then user A potentially has access to the
    Google Cloud folder F. And those advanced analysis results will be
    included in
    AnalyzeIamPolicyResponse.service_account_impersonation_analysis. Only
    the following permissions are considered in this analysis: *
    `iam.serviceAccounts.actAs` * `iam.serviceAccounts.signBlob` *
    `iam.serviceAccounts.signJwt` * `iam.serviceAccounts.getAccessToken` *
    `iam.serviceAccounts.getOpenIdToken` *
    `iam.serviceAccounts.implicitDelegation` Default is false.
  analysisQuery_options_expandGroups: Optional. If true, the identities
    section of the result will expand any Google groups appearing in an IAM
    policy binding. If IamPolicyAnalysisQuery.identity_selector is
    specified, the identity in the result will be determined by the
    selector, and this flag is not allowed to set. If true, the default max
    expansion per group is 1000 for AssetService.AnalyzeIamPolicy][].
    Default is false.
  analysisQuery_options_expandResources: Optional. If true and
    IamPolicyAnalysisQuery.resource_selector is not specified, the resource
    section of the result will expand any resource attached to an IAM policy
    to include resources lower in the resource hierarchy. For example, if
    the request analyzes for which resources user A has permission P, and
    the results include an IAM policy with P on a Google Cloud folder, the
    results will also include resources in that folder with permission P. If
    true and IamPolicyAnalysisQuery.resource_selector is specified, the
    resource section of the result will expand the specified resource to
    include resources lower in the resource hierarchy. Only project or lower
    resources are supported. Folder and organization resources cannot be
    used together with this option. For example, if the request analyzes for
    which users have permission P on a Google Cloud project with this option
    enabled, the results will include all users who have permission P on
    that project or any lower resource. If true, the default max expansion
    per resource is 1000 for AssetService.AnalyzeIamPolicy][] and 100000 for
    AssetService.AnalyzeIamPolicyLongrunning][]. Default is false.
  analysisQuery_options_expandRoles: Optional. If true, the access section
    of result will expand any roles appearing in IAM policy bindings to
    include their permissions. If IamPolicyAnalysisQuery.access_selector is
    specified, the access section of the result will be determined by the
    selector, and this flag is not allowed to set. Default is false.
  analysisQuery_options_includeDenyPolicyAnalysis: Optional. If true, the
    response includes deny policy analysis results for access tuples. The
    deny policy analysis will be conducted on max 1000 access tuples. For
    access tuples don't have deny policy analysis result populated, you can
    issue another query of that access tuple to get deny policy analysis
    result for it. Default is false.
  analysisQuery_options_outputGroupEdges: Optional. If true, the result will
    output the relevant membership relationships between groups and other
    groups, and between groups and principals. Default is false.
  analysisQuery_options_outputResourceEdges: Optional. If true, the result
    will output the relevant parent/child relationships between resources.
    Default is false.
  analysisQuery_resourceSelector_fullResourceName: Required. The [full
    resource name] (https://cloud.google.com/asset-inventory/docs/resource-
    name-format) of a resource of [supported resource
    types](https://cloud.google.com/asset-inventory/docs/supported-asset-
    types#analyzable_asset_types).
  executionTimeout: Optional. Amount of time executable has to complete. See
    JSON representation of
    [Duration](https://developers.google.com/protocol-
    buffers/docs/proto3#json). If this field is set with a value less than
    the RPC deadline, and the execution of your query hasn't finished in the
    specified execution timeout, you will get a response with partial
    result. Otherwise, your query's execution will continue until the RPC
    deadline. If it's not finished until then, you will get a
    DEADLINE_EXCEEDED error. Default is empty.
  savedAnalysisQuery: Optional. The name of a saved query, which must be in
    the format of: * projects/project_number/savedQueries/saved_query_id *
    folders/folder_number/savedQueries/saved_query_id *
    organizations/organization_number/savedQueries/saved_query_id If both
    `analysis_query` and `saved_analysis_query` are provided, they will be
    merged together with the `saved_analysis_query` as base and the
    `analysis_query` as overrides. For more details of the merge behavior,
    refer to the [MergeFrom](https://developers.google.com/protocol-buffers/
    docs/reference/cpp/google.protobuf.message#Message.MergeFrom.details)
    page. Note that you cannot override primitive fields with default value,
    such as 0 or empty string, etc., because we use proto3, which doesn't
    support field presence yet.
  scope: Required. The relative name of the root asset. Only resources and
    IAM policies within the scope will be analyzed. This can only be an
    organization number (such as "organizations/123"), a folder number (such
    as "folders/123"), a project ID (such as "projects/my-project-id"), or a
    project number (such as "projects/12345"). To know how to get
    organization ID, visit [here ](https://cloud.google.com/resource-
    manager/docs/creating-managing-
    organization#retrieving_your_organization_id). To know how to get folder
    or project ID, visit [here ](https://cloud.google.com/resource-
    manager/docs/creating-managing-
    folders#viewing_or_listing_folders_and_projects).
r   Tr   r   r   r   rh   ry   rz   r|   r~   r   r   r   r   r   r   r   r   N)r   r   r   r   r   r   r   (analysisQuery_accessSelector_permissions"analysisQuery_accessSelector_roles)analysisQuery_conditionContext_accessTime'analysisQuery_identitySelector_identityrI   8analysisQuery_options_analyzeServiceAccountImpersonation"analysisQuery_options_expandGroups%analysisQuery_options_expandResources!analysisQuery_options_expandRoles/analysisQuery_options_includeDenyPolicyAnalysis&analysisQuery_options_outputGroupEdges)analysisQuery_options_outputResourceEdges/analysisQuery_resourceSelector_fullResourceNameexecutionTimeoutr@   r   r   r   r   r   r   r     s   zx .7-B-B1t-T*'0'<'<Q'N$.7.C.CA.F+,5,A,A!,D)=F=S=STU=V:'0'='=a'@$*3*@*@*C'&/&<&<Q&?#4=4J4J14M1+4+A+A"+E(.7.D.DR.H+4=4I4I"4M1**2. ,,R0


T
2%r   r   c                       \ rS rSrSr " S S\R                  5      r\R                  " S5      r	\R                  " SSS9r
\R                  " SS	5      rS
rg)CloudassetAnalyzeMoveRequestik  a  A CloudassetAnalyzeMoveRequest object.

Enums:
  ViewValueValuesEnum: Analysis view indicating what information should be
    included in the analysis response. If unspecified, the default view is
    FULL.

Fields:
  destinationParent: Required. Name of the Google Cloud folder or
    organization to reparent the target resource. The analysis will be
    performed against hypothetically moving the resource to this specified
    destination parent. This can only be a folder number (such as
    "folders/123") or an organization number (such as "organizations/123").
  resource: Required. Name of the resource to perform the analysis against.
    Only Google Cloud projects are supported as of today. Hence, this can
    only be a project ID (such as "projects/my-project-id") or a project
    number (such as "projects/12345").
  view: Analysis view indicating what information should be included in the
    analysis response. If unspecified, the default view is FULL.
c                   $    \ rS rSrSrSrSrSrSrg)0CloudassetAnalyzeMoveRequest.ViewValueValuesEnumi  a  Analysis view indicating what information should be included in the
analysis response. If unspecified, the default view is FULL.

Values:
  ANALYSIS_VIEW_UNSPECIFIED: The default/unset value. The API will default
    to the FULL view.
  FULL: Full analysis including all level of impacts of the specified
    resource move.
  BASIC: Basic analysis only including blockers which will prevent the
    specified resource move at runtime.
r   r   r   r   N)	r   r   r   r   r   ANALYSIS_VIEW_UNSPECIFIEDFULLBASICr   r   r   r   ViewValueValuesEnumr     s    
 !"DEr   r   r   r   Tr   r   r   N)r   r   r   r   r   r   r   r   r   destinationParentr   r   viewr   r   r   r   r   r   k  sO    *INN    ++A.""1t4(			2A	6$r   r   c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " S5      r\R                  " SS	S
9rSrg)#CloudassetAnalyzeOrgPoliciesRequesti  a  A CloudassetAnalyzeOrgPoliciesRequest object.

Fields:
  constraint: Required. The name of the constraint to analyze organization
    policies for. The response only contains analyzed organization policies
    for the provided constraint.
  filter: The expression to filter
    AnalyzeOrgPoliciesResponse.org_policy_results. Filtering is currently
    available for bare literal values and the following fields: *
    consolidated_policy.attached_resource *
    consolidated_policy.rules.enforce When filtering by a specific field,
    the only supported operator is `=`. For example, filtering by consolidat
    ed_policy.attached_resource="//cloudresourcemanager.googleapis.com/folde
    rs/001" will return all the Organization Policy results attached to
    "folders/001".
  pageSize: The maximum number of items to return per page. If unspecified,
    AnalyzeOrgPoliciesResponse.org_policy_results will contain 20 items with
    a maximum of 200.
  pageToken: The pagination token to retrieve the next page.
  scope: Required. The organization to scope the request. Only organization
    policies within the scope will be analyzed. *
    organizations/{ORGANIZATION_NUMBER} (e.g., "organizations/123456")
r   r   r   r,   r   rh   Tr   r   Nr   r   r   r   r   r   r   rW   filterr1   r2   r3   pageSize	pageTokenr   r   r   r   r   r  r    si    0 $$Q'*  #&##Ay/@/@/F/FG(##A&)


D
1%r   r  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " S5      r\R                  " SS	S
9rSrg)/CloudassetAnalyzeOrgPolicyGovernedAssetsRequesti  aC  A CloudassetAnalyzeOrgPolicyGovernedAssetsRequest object.

Fields:
  constraint: Required. The name of the constraint to analyze governed
    assets for. The analysis only contains analyzed organization policies
    for the provided constraint.
  filter: The expression to filter
    AnalyzeOrgPolicyGovernedAssetsResponse.governed_assets. For governed
    resources, filtering is currently available for bare literal values and
    the following fields: * governed_resource.project *
    governed_resource.folders * consolidated_policy.rules.enforce When
    filtering by `governed_resource.project` or
    `consolidated_policy.rules.enforce`, the only supported operator is `=`.
    When filtering by `governed_resource.folders`, the supported operators
    are `=` and `:`. For example, filtering by
    `governed_resource.project="projects/12345678"` will return all the
    governed resources under "projects/12345678", including the project
    itself if applicable. For governed IAM policies, filtering is currently
    available for bare literal values and the following fields: *
    governed_iam_policy.project * governed_iam_policy.folders *
    consolidated_policy.rules.enforce When filtering by
    `governed_iam_policy.project` or `consolidated_policy.rules.enforce`,
    the only supported operator is `=`. When filtering by
    `governed_iam_policy.folders`, the supported operators are `=` and `:`.
    For example, filtering by
    `governed_iam_policy.folders:"folders/12345678"` will return all the
    governed IAM policies under "folders/001".
  pageSize: The maximum number of items to return per page. If unspecified,
    AnalyzeOrgPolicyGovernedAssetsResponse.governed_assets will contain 100
    items with a maximum of 200.
  pageToken: The pagination token to retrieve the next page.
  scope: Required. The organization to scope the request. Only organization
    policies within the scope will be analyzed. The output assets will also
    be limited to the ones governed by those in-scope organization policies.
    * organizations/{ORGANIZATION_NUMBER} (e.g., "organizations/123456")
r   r   r   r,   r   rh   Tr   r   Nr  r   r   r   r  r    sj    #J $$Q'*  #&##Ay/@/@/F/FG(##A&)


D
1%r   r  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " S5      r\R                  " SS	S
9rSrg)3CloudassetAnalyzeOrgPolicyGovernedContainersRequesti  a  A CloudassetAnalyzeOrgPolicyGovernedContainersRequest object.

Fields:
  constraint: Required. The name of the constraint to analyze governed
    containers for. The analysis only contains organization policies for the
    provided constraint.
  filter: The expression to filter
    AnalyzeOrgPolicyGovernedContainersResponse.governed_containers.
    Filtering is currently available for bare literal values and the
    following fields: * parent * consolidated_policy.rules.enforce When
    filtering by a specific field, the only supported operator is `=`. For
    example, filtering by
    parent="//cloudresourcemanager.googleapis.com/folders/001" will return
    all the containers under "folders/001".
  pageSize: The maximum number of items to return per page. If unspecified,
    AnalyzeOrgPolicyGovernedContainersResponse.governed_containers will
    contain 100 items with a maximum of 200.
  pageToken: The pagination token to retrieve the next page.
  scope: Required. The organization to scope the request. Only organization
    policies within the scope will be analyzed. The output containers will
    also be limited to the ones governed by those in-scope organization
    policies. * organizations/{ORGANIZATION_NUMBER} (e.g.,
    "organizations/123456")
r   r   r   r,   r   rh   Tr   r   Nr  r   r   r   r
  r
    si    2 $$Q'*  #&##Ay/@/@/F/FG(##A&)


D
1%r   r
  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\R                  " SSS9rSrg)CloudassetAssetsListRequesti  aC  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 to take a snapshot for. For example:
    "compute.googleapis.com/Disk". Regular expression is also supported. For
    example: * "compute.googleapis.com.*" snapshots resources whose asset
    type starts with "compute.googleapis.com". * ".*Instance" snapshots
    resources whose asset type ends with "Instance". * ".*Instance.*"
    snapshots resources whose asset type contains "Instance". See
    [RE2](https://github.com/google/re2/wiki/Syntax) for all supported
    regular expression syntax. If the regular expression does not match any
    supported asset type, an INVALID_ARGUMENT error will be returned. If
    specified, only matching assets will be returned, otherwise, it will
    snapshot all asset types. See [Introduction to Cloud Asset
    Inventory](https://cloud.google.com/asset-inventory/docs/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, folder, or project the assets
    belong to. Format: "organizations/[organization-number]" (such as
    "organizations/123"), "projects/[project-id]" (such as "projects/my-
    project-id"), "projects/[project-number]" (such as "projects/12345"), or
    "folders/[folder-number]" (such as "folders/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.
  relationshipTypes: A list of relationship types to output, for example:
    `INSTANCE_TO_INSTANCEGROUP`. This field should only be specified if
    content_type=RELATIONSHIP. * If specified: it snapshots specified
    relationships. It returns an error if any of the [relationship_types]
    doesn't belong to the supported relationship types of the [asset_types]
    or if any of the [asset_types] doesn't belong to the source types of the
    [relationship_types]. * Otherwise: it snapshots the supported
    relationships for all [asset_types] or returns an error if any of the
    [asset_types] has no relationship support. An unspecified asset types
    field means all supported asset_types. See [Introduction to Cloud Asset
    Inventory](https://cloud.google.com/asset-inventory/docs/overview) for
    all supported asset types and relationship types.
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)6CloudassetAssetsListRequest.ContentTypeValueValuesEnumi9    Asset content type. If not specified, no content but the asset name
will be returned.

Values:
  CONTENT_TYPE_UNSPECIFIED: Unspecified content type.
  RESOURCE: Resource metadata.
  IAM_POLICY: The actual IAM policy set on a resource.
  ORG_POLICY: The organization policy set on an asset.
  ACCESS_POLICY: The Access Context Manager policy set on an asset.
  OS_INVENTORY: The runtime OS Inventory information.
  RELATIONSHIP: The related resources.
r   r   r   r   r   rh   ry   r   Nr   r   r   r   r   CONTENT_TYPE_UNSPECIFIEDRESOURCE
IAM_POLICY
ORG_POLICYACCESS_POLICYOS_INVENTORYRELATIONSHIPr   r   r   r   ContentTypeValueValuesEnumr  9  -      !HJJMLLr   r  r   Tr   r   r   r,   r   rh   r   ry   rz   r   N)r   r   r   r   r   r   r   r  r   
assetTypesr   contentTyper1   r2   r3   r  r  parentreadTimerelationshipTypesr   r   r   r   r  r    s    2h9>> * $$Q6*##$@!D+##Ay/@/@/F/FG(##A&)  T2&""1%(++A=r   r  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	SS
9r\R                  " S5      r\R                  " S5      r\R                  " SSS9rSrg)&CloudassetBatchGetAssetsHistoryRequestiW  a  A CloudassetBatchGetAssetsHistoryRequest object.

Enums:
  ContentTypeValueValuesEnum: Optional. The content type.

Fields:
  assetNames: A list of the full names of the assets. See:
    https://cloud.google.com/asset-inventory/docs/resource-name-format
    Example: `//compute.googleapis.com/projects/my_project_123/zones/zone1/i
    nstances/instance1`. The request becomes a no-op if the asset name list
    is empty, and the max size of the asset name list is 100 in one request.
  contentType: Optional. The content type.
  parent: Required. The relative name of the root asset. It can only be an
    organization number (such as "organizations/123"), a project ID (such as
    "projects/my-project-id")", or a project number (such as
    "projects/12345").
  readTimeWindow_endTime: End time of the time window (inclusive). If not
    specified, the current timestamp is used instead.
  readTimeWindow_startTime: Start time of the time window (exclusive).
  relationshipTypes: Optional. A list of relationship types to output, for
    example: `INSTANCE_TO_INSTANCEGROUP`. This field should only be
    specified if content_type=RELATIONSHIP. * If specified: it outputs
    specified relationships' history on the [asset_names]. It returns an
    error if any of the [relationship_types] doesn't belong to the supported
    relationship types of the [asset_names] or if any of the [asset_names]'s
    types doesn't belong to the source types of the [relationship_types]. *
    Otherwise: it outputs the supported relationships' history on the
    [asset_names] or returns an error if any of the [asset_names]'s types
    has no relationship support. See [Introduction to Cloud Asset
    Inventory](https://cloud.google.com/asset-inventory/docs/overview) for
    all supported asset types and relationship types.
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)ACloudassetBatchGetAssetsHistoryRequest.ContentTypeValueValuesEnumiy  a  Optional. The content type.

Values:
  CONTENT_TYPE_UNSPECIFIED: Unspecified content type.
  RESOURCE: Resource metadata.
  IAM_POLICY: The actual IAM policy set on a resource.
  ORG_POLICY: The organization policy set on an asset.
  ACCESS_POLICY: The Access Context Manager policy set on an asset.
  OS_INVENTORY: The runtime OS Inventory information.
  RELATIONSHIP: The related resources.
r   r   r   r   r   rh   ry   r   Nr  r   r   r   r  r"  y  s-    
  !HJJMLLr   r  r   Tr   r   r   r   r   rh   ry   r   N)r   r   r   r   r   r   r   r  r   
assetNamesr   r  r  readTimeWindow_endTimereadTimeWindow_startTimer  r   r   r   r   r   r   W  s    B9>> ( $$Q6*##$@!D+  T2&$003&2215++A=r   r   c                   \    \ rS rSrSr\R                  " SSS9r\R                  " SSS9rSr	g	)
-CloudassetEffectiveIamPoliciesBatchGetRequesti  a+  A CloudassetEffectiveIamPoliciesBatchGetRequest object.

Fields:
  names: Required. The names refer to the [full_resource_names]
    (https://cloud.google.com/asset-inventory/docs/resource-name-format) of
    the asset types [supported by search
    APIs](https://cloud.google.com/asset-inventory/docs/supported-asset-
    types). A maximum of 20 resources' effective policies can be retrieved
    in a batch.
  scope: Required. Only IAM policies on or below the scope will be returned.
    This can only be an organization number (such as "organizations/123"), a
    folder number (such as "folders/123"), a project ID (such as
    "projects/my-project-id"), or a project number (such as
    "projects/12345"). To know how to get organization ID, visit [here
    ](https://cloud.google.com/resource-manager/docs/creating-managing-
    organization#retrieving_your_organization_id). To know how to get folder
    or project ID, visit [here ](https://cloud.google.com/resource-
    manager/docs/creating-managing-
    folders#viewing_or_listing_folders_and_projects).
r   Tr   r   r   r   N)
r   r   r   r   r   r   r   namesr   r   r   r   r   r'  r'    s-    * 

D
1%


D
1%r   r'  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
CloudassetExportAssetsRequesti  a  A CloudassetExportAssetsRequest object.

Fields:
  exportAssetsRequest: A ExportAssetsRequest resource to be passed as the
    request body.
  parent: Required. The relative name of the root asset. This can only be an
    organization number (such as "organizations/123"), a project ID (such as
    "projects/my-project-id"), or a project number (such as
    "projects/12345"), or a folder number (such as "folders/123").
ExportAssetsRequestr   r   Tr   r   N)r   r   r   r   r   r   r.   exportAssetsRequestr   r  r   r   r   r   r*  r*    s/    	 "../DaH  T2&r   r*  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
CloudassetFeedsCreateRequesti  a  A CloudassetFeedsCreateRequest object.

Fields:
  createFeedRequest: A CreateFeedRequest resource to be passed as the
    request body.
  parent: Required. The name of the project/folder/organization where this
    feed should be created in. It can only be an organization number (such
    as "organizations/123"), a folder number (such as "folders/123"), a
    project ID (such as "projects/my-project-id"), or a project number (such
    as "projects/12345").
CreateFeedRequestr   r   Tr   r   N)r   r   r   r   r   r   r.   createFeedRequestr   r  r   r   r   r   r.  r.    s/    
  ,,-@!D  T2&r   r.  c                   :    \ rS rSrSr\R                  " SSS9rSrg)CloudassetFeedsDeleteRequesti  zA CloudassetFeedsDeleteRequest object.

Fields:
  name: Required. The name of the feed and it must be in the format of:
    projects/project_number/feeds/feed_id
    folders/folder_number/feeds/feed_id
    organizations/organization_number/feeds/feed_id
r   Tr   r   N	r   r   r   r   r   r   r   r   r   r   r   r   r2  r2         
		q4	0$r   r2  c                   :    \ rS rSrSr\R                  " SSS9rSrg)CloudassetFeedsGetRequesti  zA CloudassetFeedsGetRequest object.

Fields:
  name: Required. The name of the Feed and it must be in the format of:
    projects/project_number/feeds/feed_id
    folders/folder_number/feeds/feed_id
    organizations/organization_number/feeds/feed_id
r   Tr   r   Nr3  r   r   r   r6  r6    r4  r   r6  c                   :    \ rS rSrSr\R                  " SSS9rSrg)CloudassetFeedsListRequesti  a  A CloudassetFeedsListRequest object.

Fields:
  parent: Required. The parent project/folder/organization whose feeds are
    to be listed. It can only be using project/folder/organization number
    (such as "folders/12345")", or a project ID (such as "projects/my-
    project-id").
r   Tr   r   N)	r   r   r   r   r   r   r   r  r   r   r   r   r8  r8    s       T2&r   r8  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
CloudassetFeedsPatchRequesti  a  A CloudassetFeedsPatchRequest object.

Fields:
  name: Required. The format will be
    projects/{project_number}/feeds/{client-assigned_feed_identifier} or
    folders/{folder_number}/feeds/{client-assigned_feed_identifier} or
    organizations/{organization_number}/feeds/{client-
    assigned_feed_identifier} The client-assigned feed identifier must be
    unique within the parent project/folder/organization.
  updateFeedRequest: A UpdateFeedRequest resource to be passed as the
    request body.
r   Tr   UpdateFeedRequestr   r   N)r   r   r   r   r   r   r   r   r.   updateFeedRequestr   r   r   r   r:  r:    s/     
		q4	0$,,-@!Dr   r:  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
CloudassetIngestAssetRequesti	  a^  A CloudassetIngestAssetRequest object.

Fields:
  closestCrmAncestor: The closest Google Cloud Resource Manager ancestor of
    the other-cloud connection through which this asset is collected. The
    format will be: organizations/, or folders/, or projects/
  ingestAssetRequest: A IngestAssetRequest resource to be passed as the
    request body.
r   Tr   IngestAssetRequestr   r   N)r   r   r   r   r   r   r   closestCrmAncestorr.   ingestAssetRequestr   r   r   r   r>  r>  	  s0     !,,Q> --.BAFr   r>  c                   :    \ rS rSrSr\R                  " SSS9rSrg)CloudassetOperationsGetRequesti  z^A CloudassetOperationsGetRequest object.

Fields:
  name: The name of the operation resource.
r   Tr   r   Nr3  r   r   r   rC  rC    s     
		q4	0$r   rC  c                       \ rS rSrSr\R                  " SS5      r\R                  " S5      r	\R                  " SSS9r
S	rg
),CloudassetOtherCloudConnectionsCreateRequesti"  a  A CloudassetOtherCloudConnectionsCreateRequest object.

Fields:
  otherCloudConnection: A OtherCloudConnection resource to be passed as the
    request body.
  otherCloudConnectionId: Required. The ID to use for the other-cloud
    connection, which will become the final component of the other-cloud
    connection's resource name. Currently only "aws" and "azure" is allowed
    as the other_cloud_connection_id.
  parent: Required. The parent resource where this connection will be
    created. It can only be an organization number (such as
    "organizations/123") for now. Format:
    organizations/{organization_number} (e.g., "organizations/123456").
OtherCloudConnectionr   r   r   Tr   r   N)r   r   r   r   r   r   r.   otherCloudConnectionr   otherCloudConnectionIdr  r   r   r   r   rE  rE  "  s@     #//0FJ$003  T2&r   rE  c                   :    \ rS rSrSr\R                  " SSS9rSrg),CloudassetOtherCloudConnectionsDeleteRequesti7  zA CloudassetOtherCloudConnectionsDeleteRequest object.

Fields:
  name: Required. The name of the other-cloud connection to delete. Format:
    organizations/{organization_number}/otherCloudConnections/{other_cloud_c
    onnection_id}
r   Tr   r   Nr3  r   r   r   rJ  rJ  7       
		q4	0$r   rJ  c                   :    \ rS rSrSr\R                  " SSS9rSrg))CloudassetOtherCloudConnectionsGetRequestiC  zA CloudassetOtherCloudConnectionsGetRequest object.

Fields:
  name: Required. The name of the other-cloud connection to retrieve.
    Format: organizations/{organization_number}/otherCloudConnections/{other
    _cloud_connection_id}
r   Tr   r   Nr3  r   r   r   rM  rM  C  rK  r   rM  c                       \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " S5      r\R                  " SSS9rS	rg
)*CloudassetOtherCloudConnectionsListRequestiO  ad  A CloudassetOtherCloudConnectionsListRequest object.

Fields:
  pageSize: Optional. The maximum number of other-cloud connections to
    return. The service may return fewer than this value. If unspecified, at
    most 50 other-cloud connections will be returned. The maximum value is
    1000; values above 1000 will be coerced to 1000.
  pageToken: Optional. A page token, received from a previous
    `ListOtherCloudConnections` call. Provide this to retrieve the
    subsequent page. When paginating, all other parameters provided to
    `ListOtherCloudConnections` must match the call that provided the page
    token.
  parent: Required. The parent resource where this connection will be
    created. It can only be an organization number (such as
    "organizations/123") for now. Format:
    organizations/{organization_number} (e.g., "organizations/123456").
r   r,   r   r   Tr   r   N)r   r   r   r   r   r   r1   r2   r3   r  r   r  r  r   r   r   r   rO  rO  O  sI    $ ##Ay/@/@/F/FG(##A&)  T2&r   rO  c                       \ rS rSrSr\R                  " SSS9r\R                  " S5      r	\R                  " SS5      r\R                  " S	5      rS
rg)+CloudassetOtherCloudConnectionsPatchRequestig  a  A CloudassetOtherCloudConnectionsPatchRequest object.

Fields:
  name: Output only. Immutable. The relative resource name of an other-cloud
    connection, which is unique across Google Cloud organizations. This
    field is used to uniquely identify other-cloud connection resource. It
    contains organization number and other_cloud_connection_id when creating
    other-cloud connection. This field is immutable once resource is
    created. And currently "aws" and "azure" are allowed as the
    other_cloud_connection_id. Format: organizations/{organization_number}/o
    therCloudConnections/{other_cloud_connection_id} E.g. -
    `organizations/123/otherCloudConnections/aws` -
    `organizations/123/otherCloudConnections/azure`
  optInFeatures_allEligibleFeatures: If true, all eligible features will be
    considered for update.
  otherCloudConnection: A OtherCloudConnection resource to be passed as the
    request body.
  updateMask: Required. The list of fields to update. A field represent
    symbolic field path of OtherCloudConnection. E.g.: paths:
    ["description", "collect_aws_asset_setting.qps_limit"] Note that
    `update_mask` cannot be empty, but it supports a special wildcard value
    `*`, meaning full replacement. The following immutable fields cannot be
    updated: - `name`, - `service_agent_id`, -
    `collect_aws_asset_setting.collector_role_name`, -
    `collect_aws_asset_setting.delegate_role_name`, -
    `collect_azure_asset_setting.tenant_id`.
r   Tr   r   rF  r   r   r   N)r   r   r   r   r   r   r   r   rI   !optInFeatures_allEligibleFeaturesr.   rG  
updateMaskr   r   r   r   rQ  rQ  g  sP    8 
		q4	0$&/&<&<Q&?#"//0FJ$$Q'*r   rQ  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
CloudassetQueryAssetsRequesti  a  A CloudassetQueryAssetsRequest object.

Fields:
  parent: Required. The relative name of the root asset. This can only be an
    organization number (such as "organizations/123"), a project ID (such as
    "projects/my-project-id"), or a project number (such as
    "projects/12345"), or a folder number (such as "folders/123"). Only
    assets belonging to the `parent` will be returned.
  queryAssetsRequest: A QueryAssetsRequest resource to be passed as the
    request body.
r   Tr   QueryAssetsRequestr   r   N)r   r   r   r   r   r   r   r  r.   queryAssetsRequestr   r   r   r   rU  rU    s/    
   T2& --.BAFr   rU  c                       \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	\R                  " S5      r
S	rg
)#CloudassetSavedQueriesCreateRequesti  aQ  A CloudassetSavedQueriesCreateRequest object.

Fields:
  parent: Required. The name of the project/folder/organization where this
    saved_query should be created in. It can only be an organization number
    (such as "organizations/123"), a folder number (such as "folders/123"),
    a project ID (such as "projects/my-project-id"), or a project number
    (such as "projects/12345").
  savedQuery: A SavedQuery resource to be passed as the request body.
  savedQueryId: Required. The ID to use for the saved query, which must be
    unique in the specified parent. It will become the final component of
    the saved query's resource name. This value should be 4-63 characters,
    and valid characters are `a-z-`. Notice that this field is required in
    the saved query creation, and the `name` field of the `saved_query` will
    be ignored.
r   Tr   
SavedQueryr   r   r   N)r   r   r   r   r   r   r   r  r.   
savedQuerysavedQueryIdr   r   r   r   rY  rY    s=    "   T2&%%lA6*&&q),r   rY  c                   :    \ rS rSrSr\R                  " SSS9rSrg)#CloudassetSavedQueriesDeleteRequesti  aC  A CloudassetSavedQueriesDeleteRequest object.

Fields:
  name: Required. The name of the saved query to delete. It must be in the
    format of: * projects/project_number/savedQueries/saved_query_id *
    folders/folder_number/savedQueries/saved_query_id *
    organizations/organization_number/savedQueries/saved_query_id
r   Tr   r   Nr3  r   r   r   r^  r^    r4  r   r^  c                   :    \ rS rSrSr\R                  " SSS9rSrg) CloudassetSavedQueriesGetRequesti  a9  A CloudassetSavedQueriesGetRequest object.

Fields:
  name: Required. The name of the saved query and it must be in the format
    of: * projects/project_number/savedQueries/saved_query_id *
    folders/folder_number/savedQueries/saved_query_id *
    organizations/organization_number/savedQueries/saved_query_id
r   Tr   r   Nr3  r   r   r   r`  r`    r4  r   r`  c                       \ rS rSrSr\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " S5      r\R                  " SSS	9rS
rg)!CloudassetSavedQueriesListRequesti  a  A CloudassetSavedQueriesListRequest object.

Fields:
  filter: Optional. The expression to filter resources. The expression is a
    list of zero or more restrictions combined via logical operators `AND`
    and `OR`. When `AND` and `OR` are both used in the expression,
    parentheses must be appropriately used to group the combinations. The
    expression may also contain regular expressions. See
    https://google.aip.dev/160 for more information on the grammar.
  pageSize: Optional. The maximum number of saved queries to return per
    page. The service may return fewer than this value. If unspecified, at
    most 50 will be returned. The maximum value is 1000; values above 1000
    will be coerced to 1000.
  pageToken: Optional. A page token, received from a previous
    `ListSavedQueries` call. Provide this to retrieve the subsequent page.
    When paginating, all other parameters provided to `ListSavedQueries`
    must match the call that provided the page token.
  parent: Required. The parent project/folder/organization whose
    savedQueries are to be listed. It can only be using
    project/folder/organization number (such as "folders/12345")", or a
    project ID (such as "projects/my-project-id").
r   r   r,   r   r   Tr   r   N)r   r   r   r   r   r   r   r  r1   r2   r3   r  r  r  r   r   r   r   rb  rb    sY    .   #&##Ay/@/@/F/FG(##A&)  T2&r   rb  c                       \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	\R                  " S5      r
S	rg
)"CloudassetSavedQueriesPatchRequesti  a  A CloudassetSavedQueriesPatchRequest object.

Fields:
  name: The resource name of the saved query. The format must be: *
    projects/project_number/savedQueries/saved_query_id *
    folders/folder_number/savedQueries/saved_query_id *
    organizations/organization_number/savedQueries/saved_query_id
  savedQuery: A SavedQuery resource to be passed as the request body.
  updateMask: Required. The list of fields to update.
r   Tr   rZ  r   r   r   N)r   r   r   r   r   r   r   r   r.   r[  rS  r   r   r   r   rd  rd    s=    	 
		q4	0$%%lA6*$$Q'*r   rd  c                      \ rS rSrSr\R                  " SSS9r\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " S	5      r\R                  " S
5      r\R                  " SSS9rSrg)%CloudassetSearchAllIamPoliciesRequesti  a  A CloudassetSearchAllIamPoliciesRequest object.

Fields:
  assetTypes: Optional. A list of asset types that the IAM policies are
    attached to. If empty, it will search the IAM policies that are attached
    to all the asset types [supported by search
    APIs](https://cloud.google.com/asset-inventory/docs/supported-asset-
    types) Regular expressions are also supported. For example: *
    "compute.googleapis.com.*" snapshots IAM policies attached to asset type
    starts with "compute.googleapis.com". * ".*Instance" snapshots IAM
    policies attached to asset type ends with "Instance". * ".*Instance.*"
    snapshots IAM policies attached to asset type contains "Instance". See
    [RE2](https://github.com/google/re2/wiki/Syntax) for all supported
    regular expression syntax. If the regular expression does not match any
    supported asset type, an INVALID_ARGUMENT error will be returned.
  orderBy: Optional. A comma-separated list of fields specifying the sorting
    order of the results. The default order is ascending. Add " DESC" after
    the field name to indicate descending order. Redundant space characters
    are ignored. Example: "assetType DESC, resource". Only singular
    primitive fields in the response are sortable: * resource * assetType *
    project All the other fields such as repeated fields (e.g., `folders`)
    and non-primitive fields (e.g., `policy`) are not supported.
  pageSize: Optional. The page size for search result pagination. Page size
    is capped at 500 even if a larger value is given. If set to zero or a
    negative value, server will pick an appropriate default. Returned
    results may be fewer than requested. When this happens, there could be
    more results as long as `next_page_token` is returned.
  pageToken: Optional. If present, retrieve the next batch of results from
    the preceding call to this method. `page_token` must be the value of
    `next_page_token` from the previous response. The values of all other
    method parameters must be identical to those in the previous call.
  query: Optional. The query statement. See [how to construct a
    query](https://cloud.google.com/asset-inventory/docs/searching-iam-
    policies#how_to_construct_a_query) for more information. If not
    specified or empty, it will search all the IAM policies within the
    specified `scope`. Note that the query string is compared against each
    IAM policy binding, including its principals, roles, and IAM conditions.
    The returned IAM policies will only contain the bindings that match your
    query. To learn more about the IAM policy structure, see the [IAM policy
    documentation](https://cloud.google.com/iam/help/allow-
    policies/structure). Examples: * `policy:amy@gmail.com` to find IAM
    policy bindings that specify user "amy@gmail.com". *
    `policy:roles/compute.admin` to find IAM policy bindings that specify
    the Compute Admin role. * `policy:comp*` to find IAM policy bindings
    that contain "comp" as a prefix of any word in the binding. *
    `policy.role.permissions:storage.buckets.update` to find IAM policy
    bindings that specify a role containing "storage.buckets.update"
    permission. Note that if callers don't have `iam.roles.get` access to a
    role's included permissions, policy bindings that specify this role will
    be dropped from the search results. * `policy.role.permissions:upd*` to
    find IAM policy bindings that specify a role containing "upd" as a
    prefix of any word in the role permission. Note that if callers don't
    have `iam.roles.get` access to a role's included permissions, policy
    bindings that specify this role will be dropped from the search results.
    * `resource:organizations/123456` to find IAM policy bindings that are
    set on "organizations/123456". *
    `resource=//cloudresourcemanager.googleapis.com/projects/myproject` to
    find IAM policy bindings that are set on the project named "myproject".
    * `Important` to find IAM policy bindings that contain "Important" as a
    word in any of the searchable fields (except for the included
    permissions). * `resource:(instance1 OR instance2) policy:amy` to find
    IAM policy bindings that are set on resources "instance1" or "instance2"
    and also specify user "amy". * `roles:roles/compute.admin` to find IAM
    policy bindings that specify the Compute Admin role. *
    `memberTypes:user` to find IAM policy bindings that contain the
    principal type "user".
  scope: Required. A scope can be a project, a folder, or an organization.
    The search is limited to the IAM policies within the `scope`. The caller
    must be granted the [`cloudasset.assets.searchAllIamPolicies`](https://c
    loud.google.com/asset-inventory/docs/access-
    control#required_permissions) permission 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")
r   Tr   r   r   r,   r   rh   ry   r   r   N)r   r   r   r   r   r   r   r  orderByr1   r2   r3   r  r  queryr   r   r   r   r   rf  rf    s}    KZ $$Q6*!!!$'##Ay/@/@/F/FG(##A&)



"%


D
1%r   rf  c                   6   \ rS rSrSr\R                  " SSS9r\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " S	5      r\R                  " S
5      r\R                  " S5      r\R                  " SSS9rSrg)#CloudassetSearchAllResourcesRequestiQ  a!  A CloudassetSearchAllResourcesRequest object.

Fields:
  assetTypes: Optional. A list of asset types that this request searches
    for. If empty, it will search all the asset types [supported by search
    APIs](https://cloud.google.com/asset-inventory/docs/supported-asset-
    types). Regular expressions are also supported. For example: *
    "compute.googleapis.com.*" snapshots resources whose asset type starts
    with "compute.googleapis.com". * ".*Instance" snapshots resources whose
    asset type ends with "Instance". * ".*Instance.*" snapshots resources
    whose asset type contains "Instance". See
    [RE2](https://github.com/google/re2/wiki/Syntax) for all supported
    regular expression syntax. If the regular expression does not match any
    supported asset type, an INVALID_ARGUMENT error will be returned.
  orderBy: Optional. A comma-separated list of fields specifying the sorting
    order of the results. The default order is ascending. Add " DESC" after
    the field name to indicate descending order. Redundant space characters
    are ignored. Example: "location DESC, name". Only the following fields
    in the response are sortable: * name * assetType * project * displayName
    * description * location * createTime * updateTime * state *
    parentFullResourceName * parentAssetType
  pageSize: Optional. The page size for search result pagination. Page size
    is capped at 500 even if a larger value is given. If set to zero or a
    negative value, server will pick an appropriate default. Returned
    results may be fewer than requested. When this happens, there could be
    more results as long as `next_page_token` is returned.
  pageToken: Optional. If present, then retrieve the next batch of results
    from the preceding call to this method. `page_token` must be the value
    of `next_page_token` from the previous response. The values of all other
    method parameters, must be identical to those in the previous call.
  query: Optional. The query statement. See [how to construct a
    query](https://cloud.google.com/asset-inventory/docs/searching-
    resources#how_to_construct_a_query) for more information. If not
    specified or empty, it will search all the resources within the
    specified `scope`. Examples: * `name:Important` to find Google Cloud
    resources whose name contains `Important` as a word. * `name=Important`
    to find the Google Cloud resource whose name is exactly `Important`. *
    `displayName:Impor*` to find Google Cloud resources whose display name
    contains `Impor` as a prefix of any word in the field. * `location:us-
    west*` to find Google Cloud resources whose location contains both `us`
    and `west` as prefixes. * `labels:prod` to find Google Cloud resources
    whose labels contain `prod` as a key or value. * `labels.env:prod` to
    find Google Cloud resources that have a label `env` and its value is
    `prod`. * `labels.env:*` to find Google Cloud resources that have a
    label `env`. * `tagKeys:env` to find Google Cloud resources that have
    directly attached tags where the
    [`TagKey.namespacedName`](https://cloud.google.com/resource-
    manager/reference/rest/v3/tagKeys#resource:-tagkey) contains `env`. *
    `tagValues:prod*` to find Google Cloud resources that have directly
    attached tags where the
    [`TagValue.namespacedName`](https://cloud.google.com/resource-
    manager/reference/rest/v3/tagValues#resource:-tagvalue) contains a word
    prefixed by `prod`. * `tagValueIds=tagValues/123` to find Google Cloud
    resources that have directly attached tags where the
    [`TagValue.name`](https://cloud.google.com/resource-
    manager/reference/rest/v3/tagValues#resource:-tagvalue) is exactly
    `tagValues/123`. * `effectiveTagKeys:env` to find Google Cloud resources
    that have directly attached or inherited tags where the
    [`TagKey.namespacedName`](https://cloud.google.com/resource-
    manager/reference/rest/v3/tagKeys#resource:-tagkey) contains `env`. *
    `effectiveTagValues:prod*` to find Google Cloud resources that have
    directly attached or inherited tags where the
    [`TagValue.namespacedName`](https://cloud.google.com/resource-
    manager/reference/rest/v3/tagValues#resource:-tagvalue) contains a word
    prefixed by `prod`. * `effectiveTagValueIds=tagValues/123` to find
    Google Cloud resources that have directly attached or inherited tags
    where the [`TagValue.name`](https://cloud.google.com/resource-
    manager/reference/rest/v3/tagValues#resource:-tagvalue) is exactly
    `tagValues/123`. * `kmsKey:key` to find Google Cloud resources encrypted
    with a customer-managed encryption key whose name contains `key` as a
    word. This field is deprecated. Use the `kmsKeys` field to retrieve
    Cloud KMS key information. * `kmsKeys:key` to find Google Cloud
    resources encrypted with customer-managed encryption keys whose name
    contains the word `key`. * `relationships:instance-group-1` to find
    Google Cloud resources that have relationships with `instance-group-1`
    in the related resource name. *
    `relationships:INSTANCE_TO_INSTANCEGROUP` to find Compute Engine
    instances that have relationships of type `INSTANCE_TO_INSTANCEGROUP`. *
    `relationships.INSTANCE_TO_INSTANCEGROUP:instance-group-1` to find
    Compute Engine instances that have relationships with `instance-group-1`
    in the Compute Engine instance group resource name, for relationship
    type `INSTANCE_TO_INSTANCEGROUP`. * `sccSecurityMarks.key=value` to find
    Cloud resources that are attached with security marks whose key is `key`
    and value is `value`. * `sccSecurityMarks.key:*` to find Cloud resources
    that are attached with security marks whose key is `key`. *
    `state:ACTIVE` to find Google Cloud resources whose state contains
    `ACTIVE` as a word. * `NOT state:ACTIVE` to find Google Cloud resources
    whose state doesn't contain `ACTIVE` as a word. *
    `createTime<1609459200` to find Google Cloud resources that were created
    before `2021-01-01 00:00:00 UTC`. `1609459200` is the epoch timestamp of
    `2021-01-01 00:00:00 UTC` in seconds. * `updateTime>1609459200` to find
    Google Cloud resources that were updated after `2021-01-01 00:00:00
    UTC`. `1609459200` is the epoch timestamp of `2021-01-01 00:00:00 UTC`
    in seconds. * `Important` to find Google Cloud resources that contain
    `Important` as a word in any of the searchable fields. * `Impor*` to
    find Google Cloud resources that contain `Impor` as a prefix of any word
    in any of the searchable fields. * `Important location:(us-west1 OR
    global)` to find Google Cloud resources that contain `Important` as a
    word in any of the searchable fields and are also located in the `us-
    west1` region or the `global` location.
  readMask: Optional. A comma-separated list of fields that you want
    returned in the results. The following fields are returned by default if
    not specified: * `name` * `assetType` * `project` * `folders` *
    `organization` * `displayName` * `description` * `location` * `labels` *
    `tags` * `effectiveTags` * `networkTags` * `kmsKeys` * `createTime` *
    `updateTime` * `state` * `additionalAttributes` *
    `parentFullResourceName` * `parentAssetType` Some fields of large size,
    such as `versionedResources`, `attachedResources`, `effectiveTags` etc.,
    are not returned by default, but you can specify them in the `read_mask`
    parameter if you want to include them. If `"*"` is specified, all
    [available fields](https://cloud.google.com/asset-inventory/docs/referen
    ce/rest/v1/TopLevel/searchAllResources#resourcesearchresult) are
    returned. Examples: `"name,location"`, `"name,versionedResources"`,
    `"*"`. Any invalid field path will trigger INVALID_ARGUMENT error.
  scope: Required. A scope can be a project, a folder, or an organization.
    The search is limited to the resources within the `scope`. The caller
    must be granted the
    [`cloudasset.assets.searchAllResources`](https://cloud.google.com/asset-
    inventory/docs/access-control#required_permissions) permission 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")
r   Tr   r   r   r,   r   rh   ry   rz   r   r   N)r   r   r   r   r   r   r   r  rg  r1   r2   r3   r  r  rh  readMaskr   r   r   r   r   rj  rj  Q  s    {z $$Q6*!!!$'##Ay/@/@/F/FG(##A&)



"%""1%(


D
1%r   rj  c                      \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                  " S	S
S9r\R                  " SS
S9r\R                   " SS5      r\R                  " SS
S9r\R                   " SS5      r\R                   " SS5      r\R                  " S5      rSrg)CollectAwsAssetSettingi  a
  The connection settings to collect asset data from AWS. This needs to be
populated if connection type is COLLECT_AWS_ASSET. We have an option to
enable scanning sensitive asset data. By default, the connection will both
collect AWS asset metadata and scan sensitive asset data.

Messages:
  QpsLimitValue: Optional. QPS rate limit for AWS API per each AWS service.
    For each entry, key is the name of AWS service and value is QPS rate
    limit.

Fields:
  collectorRoleName: Required. Immutable. AWS collector role name. Collector
    role has delegate role as trusted entity, and is used to authenticate
    access AWS config data directly for each product.
  delegateAccountId: Required. AWS delegated account id. If this account id
    is in an AWS organization, we will attempt to discover all the AWS
    accounts in that AWS organization, which is referred to as AWS Account
    Auto Discovery feature. Note that: * This feature will be disabled when
    included_aws_account_ids is set. * This feature requires the
    delegate_role_name to be able to access [ListAccounts](https://docs.aws.
    amazon.com/organizations/latest/APIReference/API_ListAccounts.html).
  delegateRoleName: Required. Immutable. AWS delegate role name. GCP Service
    Account will assume a delegate role to get authenticated, then assume
    other collector roles to get authorized to collect config data. Delegate
    role ARN format -
    arn:aws:iam::{delegate_account_id}:role/{delegate_role_name}
  excludedAwsAccountIds: Optional. List of AWS accounts to exclude. This
    list should be mutually exclusive with included_aws_account_ids.
  includedAwsAccountIds: Optional. List of AWS accounts to collect data
    from. If this is provided, the AWS Account Auto Discovery will be
    disabled. This list should be mutually exclusive with
    excluded_aws_account_ids.
  qpsLimit: Optional. QPS rate limit for AWS API per each AWS service. For
    each entry, key is the name of AWS service and value is QPS rate limit.
  regionCodes: Optional. Region codes that this connection needs to collect
    data from, like `us-east-2`. If it's empty, then all regions should be
    used. Most AWS services and APIs are region specific. If region(s) is
    not specified, the data collection process can be very time consuming as
    all regions must be queried for all metadata.
  scanSensitiveDataSetting: A ScanSensitiveDataSetting attribute.
  sensitiveDataProtectionDiscoverySetting: Optional. Sensitive Data
    Protection discovery setting.
  stsEndpointUri: Optional. AWS security token service endpoint. If a user
    disables the default global endpoint, user must provide regional
    endpoint to call for authentication.
additionalPropertiesc                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
$CollectAwsAssetSetting.QpsLimitValuei  a(  Optional. QPS rate limit for AWS API per each AWS service. For each
entry, key is the name of AWS service and value is QPS rate limit.

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

Fields:
  additionalProperties: Additional properties of type QpsLimitValue
c                       \ rS rSrSr\R                  " S5      r\R                  " S\R                  R                  S9rSrg)7CollectAwsAssetSetting.QpsLimitValue.AdditionalPropertyi  zAn additional property for a QpsLimitValue object.

Fields:
  key: Name of the additional property.
  value: A integer attribute.
r   r   r,   r   N)r   r   r   r   r   r   r   keyr1   r2   r3   valuer   r   r   r   AdditionalPropertyrr    s7    
 !!!$c$$Q	0A0A0G0GHer   ru  r   Tr   r   Nr   r   r   r   r   r   Messageru  r.   rn  r   r   r   r   QpsLimitValuerp    s4    	IY.. 	I %112FTXYr   rx  r   r   r   r   Tr   rh   ry   rz   ScanSensitiveDataSettingr|   'SensitiveDataProtectionDiscoverySettingr~   r   r   N)r   r   r   r   r   r   MapUnrecognizedFieldsr   rw  rx  r   collectorRoleNamedelegateAccountIddelegateRoleNameexcludedAwsAccountIdsincludedAwsAccountIdsr.   qpsLimitregionCodesscanSensitiveDataSetting'sensitiveDataProtectionDiscoverySettingstsEndpointUrir   r   r   r   rm  rm    s    -^ !!"89Zi'' Z :Z0  ++A.++A.**1-#//DA#//DA##OQ7(%%a$7+&334NPQR,5,B,BClno,p)((,.r   rm  c                      \ 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5      r\R                  " SS5      r\R                  " S5      rSrg)CollectAzureAssetSettingi-  a  The connection settings to collect asset data from Azure. This needs to
be populated with at least the required fields if connection type is
COLLECT_AZURE_ASSET. The Azure built-in Reader role will be assigned to the
user-assigned managed identity to collect data. This role allows read access
to resources of all types, and will include the read permissions needed by
both Attack Path Simulation and Sensitive Data Protection. And therefore
ScanSensitiveDataSetting used to configure third-party cloud environment for
Sensitive Data Protection is not included in CollectAzureAssetSetting.

Fields:
  excludedSubscriptionIds: Optional. Excluded subscription IDs.
  includedSubscriptionIds: Optional. Included subscription IDs.
  locations: Optional. A list of locations where the data will be collected
    from. It is in the same format as used in the location name in Azure
    list locations response https://learn.microsoft.com/en-
    us/rest/api/resources/subscriptions/list-locations?view=rest-
    resources-2022-12-01&tabs=HTTP#getlocationswithasubscriptionid Like
    eastus, eastus2. The location name list can be found at https://gist.git
    hub.com/ausfestivus/04e55c7d80229069bf3bc75870630ec8#results
  managedIdentityClientId: Required. The client ID of the Azure User-
    assigned Managed Identity which the Google Cloud Service Agent will be
    authenticated with. Refer [here] (https://learn.microsoft.com/en-
    us/entra/identity/managed-identities-azure-resources/how-manage-user-
    assigned-managed-identities) for the definition of a user-assigned
    managed identity. You can find its client ID following [these
    steps](https://learn.microsoft.com/en-us/entra/identity/managed-
    identities-azure-resources/how-managed-identities-work-vm#user-assigned-
    managed-identity)
  managedIdentityObjectId: Required. The object/principal ID of the Azure
    User-assigned Managed Identity which the Google Cloud Service Agent will
    be authenticated with. A service principal will be created when a
    Managed Identity is enabled. This service principal (object/principal
    ID) will be used to do role assignment to the Managed Identity to access
    the Azure resources. Refer [here](https://learn.microsoft.com/en-
    us/entra/identity/managed-identities-azure-resources/how-to-view-
    managed-identity-service-principal-portal) for detailed documentation
    about Managed Identity's Service Principal. Managed Identity's
    Object/principal ID can be found following [these
    steps](https://learn.microsoft.com/en-us/entra/identity/managed-
    identities-azure-resources/how-managed-identities-work-vm#user-assigned-
    managed-identity)
  sensitiveDataProtectionDiscoveryAzureSetting: Optional. Scan sensitive
    data setting.
  tenantId: Required. Immutable. The ID of the tenant where the data will be
    collected from Azure. A tenant is a dedicated and trusted instance of
    Microsoft Entra ID. The tenant is automatically created when your
    organization signs up for a Microsoft cloud service subscription. Refer
    [here] (https://learn.microsoft.com/en-
    us/entra/fundamentals/whatis#terminology) for detailed documentation,
    and find the tenant ID at https://learn.microsoft.com/en-
    us/entra/fundamentals/how-to-find-tenant
ExcludedSubscriptionIdsr   IncludedSubscriptionIdsr   r   Tr   r   rh   ,SensitiveDataProtectionDiscoveryAzureSettingry   rz   r   N)r   r   r   r   r   r   r.   excludedSubscriptionIdsincludedSubscriptionIdsr   	locationsmanagedIdentityClientIdmanagedIdentityObjectId,sensitiveDataProtectionDiscoveryAzureSettingtenantIdr   r   r   r   r  r  -  s    3j &223LaP%223LaP##A5)%11!4%11!41:1G1GHvxy1z.""1%(r   r  c                   <    \ rS rSrSr\R                  " S5      rSrg)ConditionContextil  zThe IAM conditions context.

Fields:
  accessTime: The hypothetical access timestamp to evaluate IAM conditions.
    Note that this value must not be earlier than the current time;
    otherwise, an INVALID_ARGUMENT error will be returned.
r   r   N)	r   r   r   r   r   r   r   
accessTimer   r   r   r   r  r  l  s     $$Q'*r   r  c                   h    \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	Sr
g)ConditionEvaluationix  zThe condition evaluation.

Enums:
  EvaluationValueValueValuesEnum: The evaluation result.

Fields:
  evaluationValue: The evaluation result.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	2ConditionEvaluation.EvaluationValueValueValuesEnumi  at  The evaluation result.

Values:
  EVALUATION_VALUE_UNSPECIFIED: Reserved for future use.
  TRUE: The evaluation result is `true`.
  FALSE: The evaluation result is `false`.
  CONDITIONAL: The evaluation result is `conditional` when the condition
    expression contains variables that are either missing input values or
    have not been supported by Policy Analyzer yet.
r   r   r   r   r   N)
r   r   r   r   r   EVALUATION_VALUE_UNSPECIFIEDTRUEFALSECONDITIONALr   r   r   r   EvaluationValueValueValuesEnumr    s    	 $% DEKr   r  r   r   N)r   r   r   r   r   r   r   r  r   evaluationValuer   r   r   r   r  r  x  s,    y~~   ''(H!L/r   r  c                       \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " SS5      r\R                  " S5      rSrg	)
Contenti  a  A Content object.

Messages:
  ContentValue: The actual content of this asset event. The key is the
    content type.

Fields:
  content: The actual content of this asset event. The key is the content
    type.
  version: The version of this content format. We use this version to refer
    to various formats stored in the content. For now, only one version of
    the format exist. Therefore, we keep it empty.
rn  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
Content.ContentValuei  zThe actual content of this asset event. The key is the content type.

Messages:
  AdditionalProperty: An additional property for a ContentValue 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)'Content.ContentValue.AdditionalPropertyi  zAn additional property for a ContentValue 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   rs  r.   rt  r   r   r   r   ru  r    ,    
 !!!$c$$%<a@er   ru  r   Tr   r   Nrv  r   r   r   ContentValuer    s4    	AY.. 	A %112FTXYr   r  r   r   r   N)r   r   r   r   r   r   r{  r   rw  r  r.   contentr   versionr   r   r   r   r  r    s[     !!"89ZY&& Z :Z. "">15'!!!$'r   r  c                   b    \ rS rSrSr\R                  " SS5      r\R                  " S5      r	Sr
g)r/  i  a  Create asset feed request.

Fields:
  feed: Required. The feed details. The field `name` must be empty and it
    will be generated in the format of:
    projects/project_number/feeds/feed_id
    folders/folder_number/feeds/feed_id
    organizations/organization_number/feeds/feed_id
  feedId: Required. This is the client-assigned asset feed identifier and it
    needs to be unique under a specific parent project/folder/organization.
Feedr   r   r   N)r   r   r   r   r   r   r.   feedr   feedIdr   r   r   r   r/  r/    s+    
 
			*$  #&r   r/  c                   h    \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	Sr
g)DataCollectori  zThe name of a partner other-cloud data collector party.

Enums:
  NameValueValuesEnum: The name of partner data collector party collecting
    the asset.

Fields:
  name: The name of partner data collector party collecting the asset.
c                        \ rS rSrSrSrSrSrg)!DataCollector.NameValueValuesEnumi  zThe name of partner data collector party collecting the asset.

Values:
  DATA_COLLECTOR_UNSPECIFIED: The data collector is unspecified.
  ATTACK_PATH_SIMULATION: <no description>
r   r   r   N)r   r   r   r   r   DATA_COLLECTOR_UNSPECIFIEDATTACK_PATH_SIMULATIONr   r   r   r   NameValueValuesEnumr    s     "#r   r  r   r   N)r   r   r   r   r   r   r   r  r   r   r   r   r   r   r  r    s,    INN  
		2A	6$r   r  c                       \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " S\R                  R                  S9r
\R                  " S\R                  R                  S9rSrg)	Datei  a  Represents a whole or partial calendar date, such as a birthday. The
time of day and time zone are either specified elsewhere or are
insignificant. The date is relative to the Gregorian Calendar. This can
represent one of the following: * A full date, with non-zero year, month,
and day values. * A month and day, with a zero year (for example, an
anniversary). * A year on its own, with a zero month and a zero day. * A
year and month, with a zero day (for example, a credit card expiration
date). Related types: * google.type.TimeOfDay * google.type.DateTime *
google.protobuf.Timestamp

Fields:
  day: Day of a month. Must be from 1 to 31 and valid for the year and
    month, or 0 to specify a year by itself or a year and month where the
    day isn't significant.
  month: Month of a year. Must be from 1 to 12, or 0 to specify a year
    without a month and day.
  year: Year of the date. Must be from 1 to 9999, or 0 to specify a date
    without a year.
r   r,   r   r   r   N)r   r   r   r   r   r   r1   r2   r3   daymonthyearr   r   r   r   r  r    sc    ( 	q)*;*;*A*AB#

 
 I,=,=,C,C
D%			9+<+<+B+B	C$r   r  c                   b    \ rS rSrSr\R                  " SS5      r\R                  " SSSS9rS	r	g
)DenyAnalysisResulti  a  A deny policy analysis result for an access tuple.

Fields:
  accessTuple: An access tuple that is conducted deny policy analysis. This
    access tuple should match at least one access tuple derived from
    IamPolicyAnalysisResult.
  denyDetails: The details about how denied_access_tuple is denied. If it is
    empty, it means no deny rule is found to have any effect on the access
    tuple.
/GoogleCloudAssetV1DenyAnalysisResultAccessTupler   .GoogleCloudAssetV1DenyAnalysisResultDenyDetailr   Tr   r   N)
r   r   r   r   r   r   r.   accessTupledenyDetailsr   r   r   r   r  r    s4    	 &&'XZ[\+&&'WYZeij+r   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
r   i  a  The effective IAM policies on one resource.

Fields:
  fullResourceName: The [full_resource_name]
    (https://cloud.google.com/asset-inventory/docs/resource-name-format) for
    which the policies are computed. This is one of the
    BatchGetEffectiveIamPoliciesRequest.names the caller provides in the
    request.
  policies: The effective policies for the full_resource_name. These
    policies include the policy set on the full_resource_name and those set
    on its parents and ancestors up to the
    BatchGetEffectiveIamPoliciesRequest.scope. Note that these policies are
    not filtered according to the resource type of the full_resource_name.
    These policies are hierarchically ordered by
    PolicyInfo.attached_resource starting from full_resource_name itself to
    its parents and ancestors, such that policies[i]'s
    PolicyInfo.attached_resource is the child of policies[i+1]'s
    PolicyInfo.attached_resource, if policies[i+1] exists.
r   
PolicyInfor   Tr   r   N)r   r   r   r   r   r   r   fullResourceNamer.   policiesr   r   r   r   r   r     s.    ( **1-##L!dC(r   r   c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
EffectiveTagDetailsi,  a  The effective tags and the ancestor resources from which they were
inherited.

Fields:
  attachedResource: The [full resource name](https://cloud.google.com/asset-
    inventory/docs/resource-name-format) of the ancestor from which
    effective_tags are inherited, according to [tag
    inheritance](https://cloud.google.com/resource-manager/docs/tags/tags-
    overview#inheritance).
  effectiveTags: The effective tags inherited from the attached_resource.
    Note that tags with the same key but different values may attach to
    resources at a different hierarchy levels. The lower hierarchy tag value
    will overwrite the higher hierarchy tag value of the same tag key. In
    this case, the tag value at the higher hierarchy level will be removed.
    For more information, see [tag
    inheritance](https://cloud.google.com/resource-manager/docs/tags/tags-
    overview#inheritance).
r   Tagr   Tr   r   N)r   r   r   r   r   r   r   rj   r.   effectiveTagsr   r   r   r   r  r  ,  s.    & **1-((DA-r   r  c                       \ rS rSrSrSrg)EmptyiD  a  A generic empty message that you can re-use to avoid defining duplicated
empty messages in your APIs. A typical example is to use it as the request
or the response type of an API method. For instance: service Foo { rpc
Bar(google.protobuf.Empty) returns (google.protobuf.Empty); }
r   NrD   r   r   r   r  r  D  s    r   r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)r  iM  zExcluded subscription IDs.

Fields:
  excludedSubscriptionIds: Optional. List of subscriptions to be excluded in
    the data collection. This list should be mutually exclusive with
    included_subscription_ids.
r   Tr   r   N)	r   r   r   r   r   r   r   r  r   r   r   r   r  r  M       &11!dCr   r  c                       \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " SS5      rSrg)	ExplanationiY  aA  Explanation about the IAM policy search result.

Messages:
  MatchedPermissionsValue: The map from roles to their included permissions
    that match the permission query (i.e., a query containing
    `policy.role.permissions:`). Example: if query
    `policy.role.permissions:compute.disk.get` matches a policy binding that
    contains owner role, the matched_permissions will be `{"roles/owner":
    ["compute.disk.get"]}`. The roles can also be found in the returned
    `policy` bindings. Note that the map is populated only for requests with
    permission queries.

Fields:
  matchedPermissions: The map from roles to their included permissions that
    match the permission query (i.e., a query containing
    `policy.role.permissions:`). Example: if query
    `policy.role.permissions:compute.disk.get` matches a policy binding that
    contains owner role, the matched_permissions will be `{"roles/owner":
    ["compute.disk.get"]}`. The roles can also be found in the returned
    `policy` bindings. Note that the map is populated only for requests with
    permission queries.
rn  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
#Explanation.MatchedPermissionsValueiq  a  The map from roles to their included permissions that match the
permission query (i.e., a query containing `policy.role.permissions:`).
Example: if query `policy.role.permissions:compute.disk.get` matches a
policy binding that contains owner role, the matched_permissions will be
`{"roles/owner": ["compute.disk.get"]}`. The roles can also be found in
the returned `policy` bindings. Note that the map is populated only for
requests with permission queries.

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

Fields:
  additionalProperties: Additional properties of type
    MatchedPermissionsValue
c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)6Explanation.MatchedPermissionsValue.AdditionalPropertyi  zAn additional property for a MatchedPermissionsValue object.

Fields:
  key: Name of the additional property.
  value: A Permissions attribute.
r   Permissionsr   r   Nr  r   r   r   ru  r    s+    
 !!!$c$$]A6er   ru  r   Tr   r   Nrv  r   r   r   MatchedPermissionsValuer  q  s2    "	7Y.. 	7 %112FTXYr   r  r   r   N)r   r   r   r   r   r   r{  r   rw  r  r.   matchedPermissionsr   r   r   r   r  r  Y  sM    . !!"89Z	 1 1 Z :Z> !--.GKr   r  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	S
5      r\R                  " S5      r\R                  " SSS9rSrg)r+  i  a	  Export asset request.

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

Fields:
  assetTypes: A list of asset types to take a snapshot for. For example:
    "compute.googleapis.com/Disk". Regular expressions are also supported.
    For example: * "compute.googleapis.com.*" snapshots resources whose
    asset type starts with "compute.googleapis.com". * ".*Instance"
    snapshots resources whose asset type ends with "Instance". *
    ".*Instance.*" snapshots resources whose asset type contains "Instance".
    See [RE2](https://github.com/google/re2/wiki/Syntax) for all supported
    regular expression syntax. If the regular expression does not match any
    supported asset type, an INVALID_ARGUMENT error will be returned. If
    specified, only matching assets will be returned, otherwise, it will
    snapshot all asset types. See [Introduction to Cloud Asset
    Inventory](https://cloud.google.com/asset-inventory/docs/overview) for
    all supported asset types.
  contentType: Asset content type. If not specified, no content but the
    asset name will be returned.
  outputConfig: Required. Output configuration indicating where the results
    will be output to.
  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.
  relationshipTypes: A list of relationship types to export, for example:
    `INSTANCE_TO_INSTANCEGROUP`. This field should only be specified if
    content_type=RELATIONSHIP. * If specified: it snapshots specified
    relationships. It returns an error if any of the [relationship_types]
    doesn't belong to the supported relationship types of the [asset_types]
    or if any of the [asset_types] doesn't belong to the source types of the
    [relationship_types]. * Otherwise: it snapshots the supported
    relationships for all [asset_types] or returns an error if any of the
    [asset_types] has no relationship support. An unspecified asset types
    field means all supported asset_types. See [Introduction to Cloud Asset
    Inventory](https://cloud.google.com/asset-inventory/docs/overview) for
    all supported asset types and relationship types.
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).ExportAssetsRequest.ContentTypeValueValuesEnumi  r  r   r   r   r   r   rh   ry   r   Nr  r   r   r   r  r    r  r   r  r   Tr   r   OutputConfigr   r   rh   r   N)r   r   r   r   r   r   r   r  r   r  r   r  r.   r?   r  r  r   r   r   r   r+  r+    st    )V9>> * $$Q6*##$@!D+'':,""1%(++A=r   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  aq  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titler   r   r   r   r   r     sI    : %%a(+$$Q'*""1%(



"%r   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S5      rS	rg
)FeatureEnablementi 	  zThe feature enablement status.

Enums:
  EnablementValueValuesEnum: Optional. The enablement status.
  FeatureIdValueValuesEnum: Required. The feature ID.

Fields:
  enablement: Optional. The enablement status.
  featureId: Required. The feature ID.
c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
+FeatureEnablement.EnablementValueValuesEnumi	  ai  Optional. The enablement status.

Values:
  ENABLEMENT_UNSPECIFIED: Unspecified.
  NOT_ELIGIBLE: The feature is not eligible for the connection.
  ELIGIBLE: The feature is eligible for the connection.
  EXPLICIT_OPTED_IN: The feature is explicitly opted in for the
    connection.
  IMPLICIT_OPTED_IN: The feature is implicitly opted in for the
    connection.
r   r   r   r   r   r   N)r   r   r   r   r   ENABLEMENT_UNSPECIFIEDNOT_ELIGIBLEELIGIBLEEXPLICIT_OPTED_INIMPLICIT_OPTED_INr   r   r   r   EnablementValueValuesEnumr  	  s%    
 LHr   r  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)*FeatureEnablement.FeatureIdValueValuesEnumi	  a  Required. The feature ID.

Values:
  FEATURE_ID_UNSPECIFIED: Unspecified.
  COLLECT_AWS_OU: Collect AWS ORGANIZATIONS and OUs for Security Posture.
  COLLECT_AWS_SNS_SUBSCRIPTION_ATTRIBUTES: Collect
    GetSubcriptionAttributes as supplementary config for
    AWS::SNS::Subscription.
  COLLECT_AWS_BEDROCK_AGENTS: Collect ListAgents as a sumpplementary
    config for AWS Bedrock types
  COLLECT_AWS_BEDROCK_KNOWLEDGE_BASES: Collect ListKnowledgeBases for type
    AWS::Bedrock::KnowledgeBase.
  COLLECT_AZURE_GRAPH_ROLES: Add permissions
    `DeviceManagementRBAC.Read.All` for type
    Microsoft.Graph/roleAssignments, Microsoft.Graph/roleDefinitions
  COLLECT_AZURE_OPENAI_TYPES: Add Cognitive Services Data Reader
    permission for type Microsoft.AIServices/openAI/assistants,
    Microsoft.AIServices/openAI/models, Microsoft.AIServices/openAI/files
    Microsoft.AIServices/openAI/fineTuningJobs
r   r   r   r   r   rh   ry   r   N)r   r   r   r   r   FEATURE_ID_UNSPECIFIEDCOLLECT_AWS_OU'COLLECT_AWS_SNS_SUBSCRIPTION_ATTRIBUTESCOLLECT_AWS_BEDROCK_AGENTS#COLLECT_AWS_BEDROCK_KNOWLEDGE_BASESCOLLECT_AZURE_GRAPH_ROLESCOLLECT_AZURE_OPENAI_TYPESr   r   r   r   FeatureIdValueValuesEnumr  	  s2    ( N./+!"*+' !!"r   r  r   r   r   N)r   r   r   r   r   r   r   r  r  r   
enablement	featureIdr   r   r   r   r  r   	  sO    	).. $# #: ""#>B*!!"<a@)r   r  c                   >   \ rS rSrSr " S S\R                  5      r\R                  " SSS9r	\R                  " SSS9r
\R                  " S	S
5      r\R                  " SS5      r\R                  " SS5      r\R                  " S5      r\R                  " SSS9rSrg)r  i?	  aV  An asset feed used to export asset updates to a destinations. An asset
feed filter controls what updates are exported. The asset feed must be
created within a project, organization, or folder. Supported destinations
are: Pub/Sub topics.

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

Fields:
  assetNames: A list of the full names of the assets to receive updates. You
    must specify either or both of asset_names and asset_types. Only asset
    updates matching specified asset_names or asset_types are exported to
    the feed. Example: `//compute.googleapis.com/projects/my_project_123/zon
    es/zone1/instances/instance1`. For a list of the full names for
    supported asset types, see [Resource name format](/asset-
    inventory/docs/resource-name-format).
  assetTypes: A list of types of the assets to receive updates. You must
    specify either or both of asset_names and asset_types. Only asset
    updates matching specified asset_names or asset_types are exported to
    the feed. Example: `"compute.googleapis.com/Disk"` For a list of all
    supported asset types, see [Supported asset types](/asset-
    inventory/docs/supported-asset-types).
  condition: A condition which determines whether an asset update should be
    published. If specified, an asset will be returned only when the
    expression evaluates to true. When set, `expression` field in the `Expr`
    must be a valid [CEL expression] (https://github.com/google/cel-spec) on
    a TemporalAsset with name `temporal_asset`. Example: a Feed with
    expression ("temporal_asset.deleted == true") will only publish Asset
    deletions. Other fields of `Expr` are optional. See our [user
    guide](https://cloud.google.com/asset-inventory/docs/monitoring-asset-
    changes-with-condition) for detailed instructions.
  contentType: Asset content type. If not specified, no content but the
    asset name and type will be returned.
  feedOutputConfig: Required. Feed output configuration defining where the
    asset updates are published to.
  name: Required. The format will be
    projects/{project_number}/feeds/{client-assigned_feed_identifier} or
    folders/{folder_number}/feeds/{client-assigned_feed_identifier} or
    organizations/{organization_number}/feeds/{client-
    assigned_feed_identifier} The client-assigned feed identifier must be
    unique within the parent project/folder/organization.
  relationshipTypes: A list of relationship types to output, for example:
    `INSTANCE_TO_INSTANCEGROUP`. This field should only be specified if
    content_type=RELATIONSHIP. * If specified: it outputs specified
    relationship updates on the [asset_names] or the [asset_types]. It
    returns an error if any of the [relationship_types] doesn't belong to
    the supported relationship types of the [asset_names] or [asset_types],
    or any of the [asset_names] or the [asset_types] doesn't belong to the
    source types of the [relationship_types]. * Otherwise: it outputs the
    supported relationships of the types of [asset_names] and [asset_types]
    or returns an error if any of the [asset_names] or the [asset_types] has
    no replationship support. See [Introduction to Cloud Asset
    Inventory](https://cloud.google.com/asset-inventory/docs/overview) for
    all supported asset types and relationship types.
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)Feed.ContentTypeValueValuesEnumiy	  a  Asset content type. If not specified, no content but the asset name
and type will be returned.

Values:
  CONTENT_TYPE_UNSPECIFIED: Unspecified content type.
  RESOURCE: Resource metadata.
  IAM_POLICY: The actual IAM policy set on a resource.
  ORG_POLICY: The organization policy set on an asset.
  ACCESS_POLICY: The Access Context Manager policy set on an asset.
  OS_INVENTORY: The runtime OS Inventory information.
  RELATIONSHIP: The related resources.
r   r   r   r   r   rh   ry   r   Nr  r   r   r   r  r  y	  r  r   r  r   Tr   r   r   r   r   FeedOutputConfigrh   ry   rz   r   N)r   r   r   r   r   r   r   r  r   r#  r  r.   r   r   r  feedOutputConfigr   r  r   r   r   r   r  r  ?	  s    7r9>> * $$Q6*$$Q6*$$VQ/)##$@!D+++,>B			q	!$++A=r   r  c                   >    \ rS rSrSr\R                  " SS5      rSrg)r  i	  zgOutput configuration for asset feed destination.

Fields:
  pubsubDestination: Destination on Pub/Sub.
PubsubDestinationr   r   N)	r   r   r   r   r   r   r.   pubsubDestinationr   r   r   r   r  r  	  s      ,,-@!Dr   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)GcsDestinationi	  a  A Cloud Storage location.

Fields:
  uri: The URI of the Cloud Storage object. It's the same URI that is used
    by gsutil. Example: "gs://bucket_name/object_name". See [Viewing and
    Editing Object Metadata](https://cloud.google.com/storage/docs/viewing-
    editing-metadata) for more information. If the specified Cloud Storage
    object already exists and there is no
    [hold](https://cloud.google.com/storage/docs/object-holds), it will be
    overwritten with the exported result.
  uriPrefix: The URI prefix of all generated Cloud Storage objects. Example:
    "gs://bucket_name/object_name_prefix". Each object URI is in format:
    "gs://bucket_name/object_name_prefix// and only contains assets for that
    type. starts from 0. Example:
    "gs://bucket_name/object_name_prefix/compute.googleapis.com/Disk/0" is
    the first shard of output objects containing all
    compute.googleapis.com/Disk assets. An INVALID_ARGUMENT error will be
    returned if file with the same name
    "gs://bucket_name/object_name_prefix" already exists.
r   r   r   N)
r   r   r   r   r   r   r   uri	uriPrefixr   r   r   r   r  r  	  s)    * 	a ###A&)r   r  c                       \ rS rSrSr\R                  " SS5      r\R                  " S5      r	\R                  " S5      r
Srg)	GoogleCloudAssetV1Accessi	  zAn IAM role or permission under analysis.

Fields:
  analysisState: The analysis state of this access.
  permission: The permission.
  role: The role.
IamPolicyAnalysisStater   r   r   r   N)r   r   r   r   r   r   r.   analysisStater   
permissionr   r   r   r   r   r  r  	  s<     (()A1E-$$Q'*			q	!$r   r  c                       \ rS rSrSr\R                  " SSSS9r\R                  " SS5      r\R                  " S	S
SS9r	\R                  " SSSS9r
Srg)#GoogleCloudAssetV1AccessControlListi	  a5  An access control list, derived from the above IAM policy binding, which
contains a set of resources and accesses. May include one item from each set
to compose an access control entry. NOTICE that there could be multiple
access control lists for one IAM policy binding. The access control lists
are created based on resource and access combinations. For example, assume
we have the following cases in one IAM policy binding: - Permission P1 and
P2 apply to resource R1 and R2; - Permission P3 applies to resource R2 and
R3; This will result in the following access control lists: -
AccessControlList 1: [R1, R2], [P1, P2] - AccessControlList 2: [R2, R3],
[P3]

Fields:
  accesses: The accesses that match one of the following conditions: - The
    access_selector, if it is specified in request; - Otherwise, access
    specifiers reachable from the policy binding's role.
  conditionEvaluation: Condition evaluation for this AccessControlList, if
    there is a condition defined in the above IAM policy binding.
  resourceEdges: Resource edges of the graph starting from the policy
    attached resource to any descendant resources. The Edge.source_node
    contains the full resource name of a parent resource and
    Edge.target_node contains the full resource name of a child resource.
    This field is present only if the output_resource_edges option is
    enabled in request.
  resources: The resources that match one of the following conditions: - The
    resource_selector, if it is specified in request; - Otherwise, resources
    reachable from the policy attached resource.
r  r   Tr   r  r   GoogleCloudAssetV1Edger   GoogleCloudAssetV1Resourcer   r   N)r   r   r   r   r   r   r.   accessesconditionEvaluationresourceEdges	resourcesr   r   r   r   r  r  	  s\    8 ##$>DQ(!../DaH(()A1tT-$$%A1tT)r   r  c                       \ rS rSrSr\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r	\R                  " SS	S
S9r
Srg)r]   i	  a(  Represents a Google Cloud asset(resource or IAM policy) governed by the
organization policies of the
AnalyzeOrgPolicyGovernedAssetsRequest.constraint.

Fields:
  consolidatedPolicy: The consolidated policy for the analyzed asset. The
    consolidated policy is computed by merging and evaluating
    AnalyzeOrgPolicyGovernedAssetsResponse.GovernedAsset.policy_bundle. The
    evaluation will respect the organization policy [hierarchy
    rules](https://cloud.google.com/resource-manager/docs/organization-
    policy/understanding-hierarchy).
  governedIamPolicy: An IAM policy governed by the organization policies of
    the AnalyzeOrgPolicyGovernedAssetsRequest.constraint.
  governedResource: A Google Cloud resource governed by the organization
    policies of the AnalyzeOrgPolicyGovernedAssetsRequest.constraint.
  policyBundle: The ordered list of all organization policies from the
    consolidated_policy.attached_resource to the scope specified in the
    request. If the constraint is defined with default policy, it will also
    appear in the list.
re   r   IGoogleCloudAssetV1AnalyzeOrgPolicyGovernedAssetsResponseGovernedIamPolicyr   HGoogleCloudAssetV1AnalyzeOrgPolicyGovernedAssetsResponseGovernedResourcer   r   Tr   r   N)r   r   r   r   r   r   r.   consolidatedPolicygovernedIamPolicygovernedResourcepolicyBundler   r   r   r   r]   r]   	  s\    * !--.A1E,,-xz{|++,vxyz''(;QN,r   r]   c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " SSS9r	\R                  " S5      r
\R                  " S	S
5      r\R                  " S5      rSrg)r  i
  a  The IAM policies governed by the organization policies of the
AnalyzeOrgPolicyGovernedAssetsRequest.constraint.

Fields:
  assetType: The asset type of the AnalyzeOrgPolicyGovernedAssetsResponse.Go
    vernedIamPolicy.attached_resource. Example:
    `cloudresourcemanager.googleapis.com/Project` See [Cloud Asset Inventory
    Supported Asset Types](https://cloud.google.com/asset-
    inventory/docs/supported-asset-types) for all supported asset types.
  attachedResource: The full resource name of the resource on which this IAM
    policy is set. Example: `//compute.googleapis.com/projects/my_project_12
    3/zones/zone1/instances/instance1`. See [Cloud Asset Inventory Resource
    Name Format](https://cloud.google.com/asset-inventory/docs/resource-
    name-format) for more information.
  folders: The folder(s) that this IAM policy belongs to, in the format of
    folders/{FOLDER_NUMBER}. This field is available when the IAM policy
    belongs (directly or cascadingly) to one or more folders.
  organization: The organization that this IAM policy belongs to, in the
    format of organizations/{ORGANIZATION_NUMBER}. This field is available
    when the IAM policy belongs (directly or cascadingly) to an
    organization.
  policy: The IAM policy directly set on the given resource.
  project: The project that this IAM policy belongs to, in the format of
    projects/{PROJECT_NUMBER}. This field is available when the IAM policy
    belongs to a project.
r   r   r   Tr   r   rx   rh   ry   r   N)r   r   r   r   r   r   r   r   rj   foldersr    r.   policyprojectr   r   r   r   r  r  
  sn    6 ##A&)**1-!!!d3'&&q),!!(A.&!!!$'r   r  c                      \ rS rSrSr\R                  " S5      r\R                  " SSSS9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)r  i,
  a  The Google Cloud resources governed by the organization policies of the
AnalyzeOrgPolicyGovernedAssetsRequest.constraint.

Fields:
  assetType: The asset type of the
    AnalyzeOrgPolicyGovernedAssetsResponse.GovernedResource.full_resource_na
    me Example: `cloudresourcemanager.googleapis.com/Project` See [Cloud
    Asset Inventory Supported Asset Types](https://cloud.google.com/asset-
    inventory/docs/supported-asset-types) for all supported asset types.
  effectiveTags: The effective tags on this resource.
  folders: The folder(s) that this resource belongs to, in the format of
    folders/{FOLDER_NUMBER}. This field is available when the resource
    belongs (directly or cascadingly) to one or more folders.
  fullResourceName: The [full resource name]
    (https://cloud.google.com/asset-inventory/docs/resource-name-format) of
    the Google Cloud resource.
  organization: The organization that this resource belongs to, in the
    format of organizations/{ORGANIZATION_NUMBER}. This field is available
    when the resource belongs (directly or cascadingly) to an organization.
  parent: The [full resource name] (https://cloud.google.com/asset-
    inventory/docs/resource-name-format) of the parent of AnalyzeOrgPolicyGo
    vernedAssetsResponse.GovernedResource.full_resource_name.
  project: The project that this resource belongs to, in the format of
    projects/{PROJECT_NUMBER}. This field is available when the resource
    belongs to a project.
r   r  r   Tr   r   r   rh   ry   rz   r   N)r   r   r   r   r   r   r   r   r.   r  r  r  r    r  r  r   r   r   r   r  r  ,
  s    6 ##A&)(()>DQ-!!!d3'**1-&&q),  #&!!!$'r   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\R                  " S5      rS	rg
)%GoogleCloudAssetV1BigQueryDestinationiQ
  a[  A BigQuery destination.

Enums:
  PartitionKeyValueValuesEnum: The partition key for BigQuery partitioned
    table.

Fields:
  dataset: Required. The BigQuery dataset in format
    "projects/projectId/datasets/datasetId", to which the analysis results
    should be exported. If this dataset does not exist, the export call will
    return an INVALID_ARGUMENT error.
  partitionKey: The partition key for BigQuery partitioned table.
  tablePrefix: Required. The prefix of the BigQuery tables to which the
    analysis results will be written. Tables will be created based on this
    table_prefix if not exist: * _analysis table will contain export
    operation's metadata. * _analysis_result will contain all the
    IamPolicyAnalysisResult. When [partition_key] is specified, both tables
    will be partitioned based on the [partition_key].
  writeDisposition: Optional. Specifies the action that occurs if the
    destination table or partition already exists. The following values are
    supported: * WRITE_TRUNCATE: If the table or partition already exists,
    BigQuery overwrites the entire table or all the partitions data. *
    WRITE_APPEND: If the table or partition already exists, BigQuery appends
    the data to the table or the latest partition. * WRITE_EMPTY: If the
    table already exists and contains data, an error is returned. The
    default value is WRITE_APPEND. Each action is atomic and only occurs if
    BigQuery is able to complete the job successfully. Details are at
    https://cloud.google.com/bigquery/docs/loading-data-
    local#appending_to_or_overwriting_a_table_using_a_local_file.
c                        \ rS rSrSrSrSrSrg)AGoogleCloudAssetV1BigQueryDestination.PartitionKeyValueValuesEnumiq
  a  The partition key for BigQuery partitioned table.

Values:
  PARTITION_KEY_UNSPECIFIED: Unspecified partition key. Tables won't be
    partitioned using this option.
  REQUEST_TIME: The time when the request is received. If specified as
    partition key, the result table(s) is partitioned by the RequestTime
    column, an additional timestamp column representing when the request
    was received.
r   r   r   N)r   r   r   r   r   PARTITION_KEY_UNSPECIFIEDREQUEST_TIMEr   r   r   r   PartitionKeyValueValuesEnumr  q
  s    	 !"Lr   r   r   r   r   r   r   N)r   r   r   r   r   r   r   r   r   r   r   partitionKeytablePrefixwriteDispositionr   r   r   r   r  r  Q
  s]    >INN  !!!$'$$%BAF,%%a(+**1-r   r  c                       \ rS rSrSrSrg)#GoogleCloudAssetV1BooleanConstrainti
  zA `Constraint` that is either enforced or not. For example a constraint
`constraints/compute.disableSerialPortAccess`. If it is enforced on a VM
instance, serial port connections will not be opened to that instance.
r   NrD   r   r   r   r%  r%  
  s    r   r%  c                       \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	\R                  " SS5      r\R                  " S5      r\R                  " S	5      r\R                  " S
S5      r\R                  " S5      rSrg)rp   i
  a  The definition of a constraint.

Enums:
  ConstraintDefaultValueValuesEnum: The evaluation behavior of this
    constraint in the absence of 'Policy'.

Fields:
  booleanConstraint: Defines this constraint as being a BooleanConstraint.
  constraintDefault: The evaluation behavior of this constraint in the
    absence of 'Policy'.
  description: Detailed description of what this `Constraint` controls as
    well as how and where it is enforced.
  displayName: The human readable name of the constraint.
  listConstraint: Defines this constraint as being a ListConstraint.
  name: The unique name of the constraint. Format of the name should be *
    `constraints/{constraint_name}` For example,
    `constraints/compute.disableSerialPortAccess`.
c                   $    \ rS rSrSrSrSrSrSrg)=GoogleCloudAssetV1Constraint.ConstraintDefaultValueValuesEnumi
  a  The evaluation behavior of this constraint in the absence of 'Policy'.

Values:
  CONSTRAINT_DEFAULT_UNSPECIFIED: This is only used for distinguishing
    unset values and should never be used.
  ALLOW: Indicate that all values are allowed for list constraints.
    Indicate that enforcement is off for boolean constraints.
  DENY: Indicate that all values are denied for list constraints. Indicate
    that enforcement is on for boolean constraints.
r   r   r   r   N)	r   r   r   r   r   CONSTRAINT_DEFAULT_UNSPECIFIEDALLOWDENYr   r   r   r    ConstraintDefaultValueValuesEnumr(  
  s    	 &'"EDr   r,  r%  r   r   r   r    GoogleCloudAssetV1ListConstraintrh   ry   r   N)r   r   r   r   r   r   r   r,  r.   booleanConstraintr   constraintDefaultr   r  displayNamelistConstraintr   r   r   r   r   rp   rp   
  s    &   ,,-RTUV))*LaP%%a(+%%a(+))*LaP.			q	!$r   rp   c                   h   \ 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	5      r\R                  " S
5      r\R                  " SSSS9r\R                  " S5      r\R                  " SSS9rSrg)ro   i
  a  The definition of a custom constraint.

Enums:
  ActionTypeValueValuesEnum: Allow or deny type.
  MethodTypesValueListEntryValuesEnum:

Fields:
  actionType: Allow or deny type.
  condition: Organization Policy condition/expression. For example:
    `resource.instanceName.matches("[production|test]_.*_(\d)+")'` or,
    `resource.management.auto_upgrade == true`
  description: Detailed information about this custom policy constraint.
  displayName: One line display name for the UI.
  methodTypes: All the operations being applied for this constraint.
  name: Name of the constraint. This is unique within the organization.
    Format of the name should be * `organizations/{organization_id}/customCo
    nstraints/{custom_constraint_id}` Example :
    "organizations/123/customConstraints/custom.createOnlyE2TypeVms"
  resourceTypes: The Resource Instance type on which this policy applies to.
    Format will be of the form : "/" Example: *
    `compute.googleapis.com/Instance`.
c                   $    \ rS rSrSrSrSrSrSrg)<GoogleCloudAssetV1CustomConstraint.ActionTypeValueValuesEnumi
  zAllow or deny type.

Values:
  ACTION_TYPE_UNSPECIFIED: Unspecified. Will results in user error.
  ALLOW: Allowed action type.
  DENY: Deny action type.
r   r   r   r   N)	r   r   r   r   r   ACTION_TYPE_UNSPECIFIEDr*  r+  r   r   r   r   ActionTypeValueValuesEnumr4  
  s      EDr   r6  c                   0    \ rS rSrSrSrSrSrSrSr	Sr
S	rg
)FGoogleCloudAssetV1CustomConstraint.MethodTypesValueListEntryValuesEnumi
  a  MethodTypesValueListEntryValuesEnum enum type.

Values:
  METHOD_TYPE_UNSPECIFIED: Unspecified. Will results in user error.
  CREATE: Constraint applied when creating the resource.
  UPDATE: Constraint applied when updating the resource.
  DELETE: Constraint applied when deleting the resource.
  REMOVE_GRANT: Constraint applied when removing an IAM grant.
  GOVERN_TAGS: Constraint applied when enforcing forced tagging.
r   r   r   r   r   rh   r   N)r   r   r   r   r   METHOD_TYPE_UNSPECIFIEDCREATEUPDATEDELETEREMOVE_GRANTGOVERN_TAGSr   r   r   r   #MethodTypesValueListEntryValuesEnumr8  
  s(    	  FFFLKr   r?  r   r   r   r   rh   Tr   ry   rz   r   N)r   r   r   r   r   r   r   r6  r?  r   
actionTyper   r   r  r0  methodTypesr   resourceTypesr   r   r   r   ro   ro   
  s    .
).. 
INN $ ""#>B*##A&)%%a(+%%a(+##$I1W[\+			q	!$''D9-r   ro   c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)*GoogleCloudAssetV1DenyAnalysisResultAccessi
  zAn IAM role or permission under analysis.

Fields:
  permission: The IAM permission in [v1
    format](https://cloud.google.com/iam/docs/permissions-reference)
  role: The IAM role.
r   r   r   N)
r   r   r   r   r   r   r   r  r   r   r   r   r   rD  rD  
  s)     $$Q'*			q	!$r   rD  c                       \ rS rSrSr\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r	S	r
g
)r  i  aP  An access tuple contains a tuple of a resource, an identity and an
access.

Fields:
  access: One access from
    IamPolicyAnalysisResult.AccessControlList.accesses.
  identity: One identity from
    IamPolicyAnalysisResult.IdentityList.identities.
  resource: One resource from
    IamPolicyAnalysisResult.AccessControlList.resources.
rD  r   ,GoogleCloudAssetV1DenyAnalysisResultIdentityr   ,GoogleCloudAssetV1DenyAnalysisResultResourcer   r   N)r   r   r   r   r   r   r.   accessidentityr   r   r   r   r   r  r    sE    
 !!"NPQR&##$RTUV(##$RTUV(r   r  c                       \ rS rSrSr\R                  " SSSS9r\R                  " SS5      r\R                  " S	S
SS9r	\R                  " S	SSS9r
\R                  " SSSS9rSrg)r  i  a  A deny detail that explains which IAM deny rule denies the
denied_access_tuple.

Fields:
  accesses: The accesses that are denied. This could be the
    AccessTuple.access, or a subset of it. For example, if the
    AccessTuple.access is a role, this field could contain permissions in
    that role that are denied.
  denyRule: A deny rule in an IAM deny policy.
  exceptionIdentities: The identities that are exceptions from deny. This
    field is populated when: * The deny_rule has `exception_principals`; *
    For each exception_principal EP, EP is IN identities;
  identities: The identities that are denied. This could be the
    AccessTuple.identity, or its subset. For example, if the
    AccessTuple.identity is a group, this field could contain user accounts
    in that group that are denied. This field is populated with: * The
    [AccessTuple.identity] if it's IN the deny_rule's `denied_principals`,
    and not IN the `exception_principals`; * For each denied principal DP in
    the deny_rule's `denied_principals`, DP is s IN the
    [AccessTuple.identity] and not IN the `exception_principals`; The IN
    operator is defined as below: * An identity is in an identities list,
    e.g.: user:foo@ in [user:foo@, user:bar@, group:baz@]; * An identity is
    in a member of an identity of a list, e.g.: user:foo@ is a member of
    group:baz@, which is in a list [user:bar@, group:baz@];
  resources: The resources that are denied. This could be the
    AccessTuple.resource, or its descendant resources. For example, if the
    AccessTuple.resource is a project, this field could contain BigQuery
    datasets in that project that are denied.
rD  r   Tr   GoogleIamV2DenyRuler   rF  r   r   rG  rh   r   N)r   r   r   r   r   r   r.   r
  denyRuleexceptionIdentities
identitiesr  r   r   r   r   r  r    sy    < ##$PRS^bc(##$91=(!../]_`kop%%&TVWbfg*$$%SUVaef)r   r  c                   <    \ rS rSrSr\R                  " S5      rSrg)rF  i<  a  An identity under analysis.

Fields:
  name: The identity of members, formatted as appear in an [IAM policy
    binding](https://cloud.google.com/iam/reference/rest/v1/Binding). For
    example, they might be formatted like the following: -
    user:foo@google.com - group:group1@google.com -
    serviceAccount:s1@prj1.iam.gserviceaccount.com -
    projectOwner:some_project_id - domain:google.com - allUsers
r   r   Nr3  r   r   r   rF  rF  <  s    	 
		q	!$r   rF  c                   <    \ rS rSrSr\R                  " S5      rSrg)rG  iK  zA Google Cloud resource under analysis.

Fields:
  fullResourceName: The [full resource name](https://cloud.google.com/asset-
    inventory/docs/resource-name-format)
r   r   N	r   r   r   r   r   r   r   r  r   r   r   r   rG  rG  K  s     **1-r   rG  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)r  iV  a7  A directional edge.

Fields:
  sourceNode: The source node of the edge. For example, it could be a full
    resource name for a resource node or an email of an identity.
  targetNode: The target node of the edge. For example, it could be a full
    resource name for a resource node or an email of an identity.
r   r   r   N)
r   r   r   r   r   r   r   
sourceNode
targetNoder   r   r   r   r  r  V  s)     $$Q'*$$Q'*r   r  c                   <    \ rS rSrSr\R                  " S5      rSrg) GoogleCloudAssetV1GcsDestinationid  a  A Cloud Storage location.

Fields:
  uri: Required. The URI of the Cloud Storage object. It's the same URI that
    is used by gsutil. Example: "gs://bucket_name/object_name". See [Viewing
    and Editing Object
    Metadata](https://cloud.google.com/storage/docs/viewing-editing-
    metadata) for more information. If the specified Cloud Storage object
    already exists and there is no
    [hold](https://cloud.google.com/storage/docs/object-holds), it will be
    overwritten with the analysis result.
r   r   N)	r   r   r   r   r   r   r   r  r   r   r   r   rV  rV  d  s     	a #r   rV  c                   8   \ rS rSrSr\R                  " SS5      r\R                  " SSSS9r\R                  " S	SS9r
\R                  " S
5      r\R                  " S5      r\R                  " S5      r\R                  " SSSS9r\R                  " S5      rSrg)rb   iu  a-  The organization/folder/project resource governed by organization
policies of AnalyzeOrgPolicyGovernedContainersRequest.constraint.

Fields:
  consolidatedPolicy: The consolidated organization policy for the analyzed
    resource. The consolidated organization policy is computed by merging
    and evaluating AnalyzeOrgPolicyGovernedContainersResponse.GovernedContai
    ner.policy_bundle. The evaluation will respect the organization policy
    [hierarchy rules](https://cloud.google.com/resource-
    manager/docs/organization-policy/understanding-hierarchy).
  effectiveTags: The effective tags on this resource.
  folders: The folder(s) that this resource belongs to, in the format of
    folders/{FOLDER_NUMBER}. This field is available when the resource
    belongs (directly or cascadingly) to one or more folders.
  fullResourceName: The [full resource name]
    (https://cloud.google.com/asset-inventory/docs/resource-name-format) of
    an organization/folder/project resource.
  organization: The organization that this resource belongs to, in the
    format of organizations/{ORGANIZATION_NUMBER}. This field is available
    when the resource belongs (directly or cascadingly) to an organization.
  parent: The [full resource name] (https://cloud.google.com/asset-
    inventory/docs/resource-name-format) of the parent of AnalyzeOrgPolicyGo
    vernedContainersResponse.GovernedContainer.full_resource_name.
  policyBundle: The ordered list of all organization policies from the
    consolidated_policy.attached_resource. to the scope specified in the
    request. If the constraint is defined with default policy, it will also
    appear in the list.
  project: The project that this resource belongs to, in the format of
    projects/{PROJECT_NUMBER}. This field is available when the resource
    belongs to a project.
re   r   r  r   Tr   r   r   rh   ry   rz   r|   r   N)r   r   r   r   r   r   r.   r  r  r   r  r  r    r  r  r  r   r   r   r   rb   rb   u  s    @ !--.A1E(()>DQ-!!!d3'**1-&&q),  #&''(;QN,!!!$'r   rb   c                   b    \ rS rSrSr\R                  " SS5      r\R                  " S5      r	Sr
g)GoogleCloudAssetV1Identityi  a  An identity under analysis.

Fields:
  analysisState: The analysis state of this identity.
  name: The identity of members, formatted as appear in an [IAM policy
    binding](https://cloud.google.com/iam/reference/rest/v1/Binding). For
    example, they might be formatted like the following: -
    user:foo@google.com - group:group1@google.com -
    serviceAccount:s1@prj1.iam.gserviceaccount.com -
    projectOwner:some_project_id - domain:google.com - allUsers
r  r   r   r   N)r   r   r   r   r   r   r.   r  r   r   r   r   r   r   rY  rY    s,    
 (()A1E-			q	!$r   rY  c                   `    \ rS rSrSr\R                  " SSSS9r\R                  " SSSS9rS	r	g
)GoogleCloudAssetV1IdentityListi  a  The identities and group edges.

Fields:
  groupEdges: Group identity edges of the graph starting from the binding's
    group members to any node of the identities. The Edge.source_node
    contains a group, such as `group:parent@google.com`. The
    Edge.target_node contains a member of the group, such as
    `group:child@google.com` or `user:foo@google.com`. This field is present
    only if the output_group_edges option is enabled in request.
  identities: Only the identities that match one of the following conditions
    will be presented: - The identity_selector, if it is specified in
    request; - Otherwise, identities reachable from the policy binding's
    members.
r  r   Tr   rY  r   r   N)
r   r   r   r   r   r   r.   
groupEdgesrN  r   r   r   r   r[  r[    s4     %%&>DQ*%%&BAPTU*r   r[  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)r-  i  ap  A `Constraint` that allows or disallows a list of string values, which
are configured by an organization's policy administrator with a `Policy`.

Fields:
  supportsIn: Indicates whether values grouped into categories can be used
    in `Policy.allowed_values` and `Policy.denied_values`. For example,
    `"in:Python"` would match any value in the 'Python' group.
  supportsUnder: Indicates whether subtrees of Cloud Resource Manager
    resource hierarchy can be used in `Policy.allowed_values` and
    `Policy.denied_values`. For example, `"under:folders/123"` would match
    any resource under the 'folders/123' folder.
r   r   r   N)
r   r   r   r   r   r   rI   
supportsInsupportsUnderr   r   r   r   r-  r-    s)     %%a(*((+-r   r-  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S5      r	Sr
g)<GoogleCloudAssetV1QueryAssetsOutputConfigBigQueryDestinationi  a  BigQuery destination.

Fields:
  dataset: Required. The BigQuery dataset where the query results will be
    saved. It has the format of "projects/{projectId}/datasets/{datasetId}".
  table: Required. The BigQuery table where the query results will be saved.
    If this table does not exist, a new table with the given name will be
    created.
  writeDisposition: Specifies the action that occurs if the destination
    table or partition already exists. The following values are supported: *
    WRITE_TRUNCATE: If the table or partition already exists, BigQuery
    overwrites the entire table or all the partitions data. * WRITE_APPEND:
    If the table or partition already exists, BigQuery appends the data to
    the table or the latest partition. * WRITE_EMPTY: If the table already
    exists and contains data, a 'duplicate' error is returned in the job
    result. The default value is WRITE_EMPTY.
r   r   r   r   N)r   r   r   r   r   r   r   r   r   r#  r   r   r   r   ra  ra    s:    $ !!!$'



"%**1-r   ra  c                   b    \ rS rSrSr\R                  " SS5      r\R                  " S5      r	Sr
g)r	  i  zA Google Cloud resource under analysis.

Fields:
  analysisState: The analysis state of this resource.
  fullResourceName: The [full resource name](https://cloud.google.com/asset-
    inventory/docs/resource-name-format)
r  r   r   r   N)r   r   r   r   r   r   r.   r  r   r  r   r   r   r   r	  r	    s-     (()A1E-**1-r   r	  c                       \ rS rSrSr\R                  " S5      r\R                  " SS5      r	\R                  " SS5      r
\R                  " S5      r\R                  " S	5      r\R                  " S
S5      rSrg)rg   i  as  This rule message is a customized version of the one defined in the
Organization Policy system. In addition to the fields defined in the
original organization policy, it contains additional field(s) under specific
circumstances to support analysis results.

Fields:
  allowAll: Setting this to true means that all values are allowed. This
    field can be set only in Policies for list constraints.
  condition: The evaluating condition for this rule.
  conditionEvaluation: The condition evaluation result for this rule. Only
    populated if it meets all the following criteria: * There is a condition
    defined for this rule. * This rule is within AnalyzeOrgPolicyGovernedCon
    tainersResponse.GovernedContainer.consolidated_policy, or
    AnalyzeOrgPolicyGovernedAssetsResponse.GovernedAsset.consolidated_policy
    when the AnalyzeOrgPolicyGovernedAssetsResponse.GovernedAsset has
    AnalyzeOrgPolicyGovernedAssetsResponse.GovernedAsset.governed_resource.
  denyAll: Setting this to true means that all values are denied. This field
    can be set only in Policies for list constraints.
  enforce: If `true`, then the `Policy` is enforced. If `false`, then any
    configuration is acceptable. This field can be set only in Policies for
    boolean constraints.
  values: List of values to be used for this policy rule. This field can be
    set only in policies for list constraints.
r   r   r   r  r   r   rh   GoogleCloudAssetV1StringValuesry   r   N)r   r   r   r   r   r   rI   allowAllr.   r   r  denyAllenforcevaluesr   r   r   r   rg   rg     sr    2 ##A&($$VQ/)!../DaH""1%'""1%'!!"BAF&r   rg   c                   \    \ rS rSrSr\R                  " SSS9r\R                  " SSS9rSr	g)	rd  i  zThe string values for the list constraints.

Fields:
  allowedValues: List of values allowed at this resource.
  deniedValues: List of values denied at this resource.
r   Tr   r   r   N)
r   r   r   r   r   r   r   allowedValuesdeniedValuesr   r   r   r   rd  rd    s-     ''D9-&&q48,r   rd  c                      \ 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SSS	9r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R                  " S5      rSrg)GoogleCloudAssetV1p7beta1Asseti*  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. 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 IAM policy set on a Google Cloud
    resource. There can be a maximum of one IAM policy set on any given
    resource. In addition, 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/help/allow-policies/inheritance) for
    more information.
  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.
  relatedAssets: The related assets of the asset of one relationship type.
    One asset only represents one type of relationship.
  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).
  updateTime: The last update timestamp of an asset. update_time is updated
    when create/update/delete operation is performed.
ru   r   rv   r   r   Tr   r   rx   rh   ry   r{   rz   &GoogleCloudAssetV1p7beta1RelatedAssetsr|   !GoogleCloudAssetV1p7beta1Resourcer~   r   r   r   r   N)r   r   r   r   r   r   r.   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   rm  rm  *  s    1f &&'XZ[\+''(Z\]^,##A5)##A&)$$Xq1)			q	!$$$%CQQUV)(()QSTU-##$GK(++,bdfg$$R(*r   rm  c                       \ rS rSrSr\R                  " SSS9r\R                  " S5      r\R                  " S5      r	Sr
g	)
%GoogleCloudAssetV1p7beta1RelatedAssetik  aJ  An asset identify in Google Cloud which contains its name, type and
ancestors. 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.
IAM policy). See [Supported asset types](https://cloud.google.com/asset-
inventory/docs/supported-asset-types) for more information.

Fields:
  ancestors: The ancestors 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. Example: `["projects/123456789",
    "folders/5432", "organizations/1234"]`
  asset: The full name of the asset. Example: `//compute.googleapis.com/proj
    ects/my_project_123/zones/zone1/instances/instance1` See [Resource names
    ](https://cloud.google.com/apis/design/resource_names#full_resource_name
    ) for more information.
  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.
r   Tr   r   r   r   N)r   r   r   r   r   r   r   r   assetr   r   r   r   r   rq  rq  k  s;    0 ##A5)



"%##A&)r   rq  c                   b    \ rS rSrSr\R                  " SSSS9r\R                  " SS5      rS	r	g
)rn  i  zThe detailed related assets with the `relationship_type`.

Fields:
  assets: The peer resources of the relationship.
  relationshipAttributes: The detailed relation attributes.
rq  r   Tr   /GoogleCloudAssetV1p7beta1RelationshipAttributesr   r   N
r   r   r   r   r   r   r.   r   relationshipAttributesr   r   r   r   rn  rn    s4     !!"I1W[\&$112cefgr   rn  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)	rt  i  a  The relationship attributes which include `type`,
`source_resource_type`, `target_resource_type` and `action`.

Fields:
  action: The detail of the relationship, e.g. `contains`, `attaches`
  sourceResourceType: The source asset type. Example:
    `compute.googleapis.com/Instance`
  targetResourceType: The target asset type. Example:
    `compute.googleapis.com/Disk`
  type: The unique identifier of the relationship type. Example:
    `INSTANCE_TO_INSTANCEGROUP`
r   r   r   r   r   Nr   r   r   r   r   r   r   actionsourceResourceTypetargetResourceTypetyper   r   r   r   rt  rt    sK       #& ,,Q/ ,,Q/			q	!$r   rt  c                   j   \ rS rSrS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	5      r\R                  " S
5      r\R                  " S5      r\R                  " S5      rSrg)ro  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.

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.
  location: The location of the resource in Google Cloud, such as its zone
    and region. For more information, see
    https://cloud.google.com/about/locations/.
  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 [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`
rn  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
+GoogleCloudAssetV1p7beta1Resource.DataValuei  The 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)>GoogleCloudAssetV1p7beta1Resource.DataValue.AdditionalPropertyi  An additional property for a DataValue object.

Fields:
  key: Name of the additional property.
  value: A extra_types.JsonValue attribute.
r   r  r   r   Nr  r   r   r   ru  r    r  r   ru  r   Tr   r   Nrv  r   r   r   	DataValuer    4    	AY.. 	A %112FTXYr   r  r   r   r   r   rh   ry   rz   r   Nr   r   r   r   r   r   r{  r   rw  r  r.   datar   discoveryDocumentUridiscoveryNamer  r  resourceUrlr  r   r   r   r   ro  ro    s     D !!"89Z)## Z :Z0 
		Q	/$"..q1''*-""1%(  #&%%a(+!!!$'r   ro  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   rI   enforcedr   r   r   r   r  r    s    @ ##A&(r   r  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) GoogleCloudOrgpolicyV1ListPolicyi  a  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/", e.g. "projects/tokyo-rain-123" -
"folders/", e.g. "folders/1234" - "organizations/", 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.AllValuesValueValuesEnumiq  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_UNSPECIFIEDr*  r+  r   r   r   r   AllValuesValueValuesEnumr  q  s     EDr   r  r   r   Tr   r   r   rh   r   N)r   r   r   r   r   r   r   r  r   	allValuesr   rj  rk  rI   rk   suggestedValuer   r   r   r   r  r    ss    \|  !!"<a@)''D9-&&q48,,,Q/((+.r   r  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;
r  r   r   r   r  r   $GoogleCloudOrgpolicyV1RestoreDefaultrh   ry   rz   r,   r   N)r   r   r   r   r   r   r.   booleanPolicyr   rW   
BytesFieldetag
listPolicyrestoreDefaultr   r1   r2   r3   r  r   r   r   r   r{   r{     s    < (()NPQR-$$Q'*			a	 $%%&H!L*))*PRST.$$Q'*""1i.?.?.E.EF'r   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   NrD   r   r   r   r  r    s    
r   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	SS9r\R                  " S
SS9rSrg)rK  i  a-  A deny rule in an IAM deny policy.

Fields:
  denialCondition: The condition that determines whether this deny rule
    applies to a request. If the condition expression evaluates to `true`,
    then the deny rule is applied; otherwise, the deny rule is not applied.
    Each deny rule is evaluated independently. If this deny rule does not
    apply to a request, other deny rules might still apply. The condition
    can use CEL functions that evaluate [resource
    tags](https://cloud.google.com/iam/help/conditions/resource-tags). Other
    functions and operators are not supported.
  deniedPermissions: The permissions that are explicitly denied by this
    rule. Each permission uses the format
    `{service_fqdn}/{resource}.{verb}`, where `{service_fqdn}` is the fully
    qualified domain name for the service. For example,
    `iam.googleapis.com/roles.list`.
  deniedPrincipals:  The identities that are prevented from using one or
    more permissions on Google Cloud resources. This field can contain the
    following values: * `principal://goog/subject/{email_id}`: A specific
    Google Account. Includes Gmail, Cloud Identity, and Google Workspace
    user accounts. For example,
    `principal://goog/subject/alice@example.com`. * `principal://iam.googlea
    pis.com/projects/-/serviceAccounts/{service_account_id}`: A Google Cloud
    service account. For example,
    `principal://iam.googleapis.com/projects/-/serviceAccounts/my-service-
    account@iam.gserviceaccount.com`. *
    `principalSet://goog/group/{group_id}`: A Google group. For example,
    `principalSet://goog/group/admins@example.com`. *
    `principalSet://goog/public:all`: A special identifier that represents
    any principal that is on the internet, even if they do not have a Google
    Account or are not logged in. *
    `principalSet://goog/cloudIdentityCustomerId/{customer_id}`: All of the
    principals associated with the specified Google Workspace or Cloud
    Identity customer ID. For example,
    `principalSet://goog/cloudIdentityCustomerId/C01Abc35`. * `principal://i
    am.googleapis.com/locations/global/workforcePools/{pool_id}/subject/{sub
    ject_attribute_value}`: A single identity in a workforce identity pool.
    * `principalSet://iam.googleapis.com/locations/global/workforcePools/{po
    ol_id}/group/{group_id}`: All workforce identities in a group. * `princi
    palSet://iam.googleapis.com/locations/global/workforcePools/{pool_id}/at
    tribute.{attribute_name}/{attribute_value}`: All workforce identities
    with a specific attribute value. * `principalSet://iam.googleapis.com/lo
    cations/global/workforcePools/{pool_id}/*`: All identities in a
    workforce identity pool. * `principal://iam.googleapis.com/projects/{pro
    ject_number}/locations/global/workloadIdentityPools/{pool_id}/subject/{s
    ubject_attribute_value}`: A single identity in a workload identity pool.
    * `principalSet://iam.googleapis.com/projects/{project_number}/locations
    /global/workloadIdentityPools/{pool_id}/group/{group_id}`: A workload
    identity pool group. * `principalSet://iam.googleapis.com/projects/{proj
    ect_number}/locations/global/workloadIdentityPools/{pool_id}/attribute.{
    attribute_name}/{attribute_value}`: All identities in a workload
    identity pool with a certain attribute. * `principalSet://iam.googleapis
    .com/projects/{project_number}/locations/global/workloadIdentityPools/{p
    ool_id}/*`: All identities in a workload identity pool. * `principalSet:
    //cloudresourcemanager.googleapis.com/[projects|folders|organizations]/{
    project_number|folder_number|org_number}/type/ServiceAccount`: All
    service accounts grouped under a resource (project, folder, or
    organization). * `principalSet://cloudresourcemanager.googleapis.com/[pr
    ojects|folders|organizations]/{project_number|folder_number|org_number}/
    type/ServiceAgent`: All service agents grouped under a resource
    (project, folder, or organization). *
    `deleted:principal://goog/subject/{email_id}?uid={uid}`: A specific
    Google Account that was deleted recently. For example,
    `deleted:principal://goog/subject/alice@example.com?uid=1234567890`. If
    the Google Account is recovered, this identifier reverts to the standard
    identifier for a Google Account. *
    `deleted:principalSet://goog/group/{group_id}?uid={uid}`: A Google group
    that was deleted recently. For example,
    `deleted:principalSet://goog/group/admins@example.com?uid=1234567890`.
    If the Google group is restored, this identifier reverts to the standard
    identifier for a Google group. * `deleted:principal://iam.googleapis.com
    /projects/-/serviceAccounts/{service_account_id}?uid={uid}`: A Google
    Cloud service account that was deleted recently. For example,
    `deleted:principal://iam.googleapis.com/projects/-/serviceAccounts/my-
    service-account@iam.gserviceaccount.com?uid=1234567890`. If the service
    account is undeleted, this identifier reverts to the standard identifier
    for a service account. * `deleted:principal://iam.googleapis.com/locatio
    ns/global/workforcePools/{pool_id}/subject/{subject_attribute_value}`:
    Deleted single identity in a workforce identity pool. For example, `dele
    ted:principal://iam.googleapis.com/locations/global/workforcePools/my-
    pool-id/subject/my-subject-attribute-value`.
  exceptionPermissions: Specifies the permissions that this rule excludes
    from the set of denied permissions given by `denied_permissions`. If a
    permission appears in `denied_permissions` _and_ in
    `exception_permissions` then it will _not_ be denied. The excluded
    permissions can be specified using the same syntax as
    `denied_permissions`.
  exceptionPrincipals: The identities that are excluded from the deny rule,
    even if they are listed in the `denied_principals`. For example, you
    could add a Google group to the `denied_principals`, then exclude
    specific users who belong to that group. This field can contain the same
    values as the `denied_principals` field, excluding
    `principalSet://goog/public:all`, which represents all users on the
    internet.
r   r   r   Tr   r   r   rh   r   N)r   r   r   r   r   r   r.   denialConditionr   deniedPermissionsdeniedPrincipalsexceptionPermissionsexceptionPrincipalsr   r   r   r   rK  rK    si    ^@ **615/++A=**1t<"..q4@!--a$?r   rK  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)ru   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: Identifier. Resource name for the `AccessLevel`. Format:
    `accessPolicies/{access_policy}/accessLevels/{access_level}`. The
    `access_level` component must begin with a letter, followed by
    alphanumeric characters or `_`. Its maximum length is 50 characters.
    After you create an `AccessLevel`, you cannot change its `name`.
  title: Human readable title. Must be unique within the Policy.
.GoogleIdentityAccesscontextmanagerV1BasicLevelr   /GoogleIdentityAccesscontextmanagerV1CustomLevelr   r   r   rh   r   N)r   r   r   r   r   r   r.   basiccustomr   r  r   r  r   r   r   r   ru   ru   $  sa    " 
 
 !QST
U%!!"SUVW&%%a(+			q	!$



"%r   ru   c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S5      r	\R                  " SSS9r
\R                  " S	5      rS
rg)rv   i=  a8  `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 Policies 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. Identifier. Resource name of the `AccessPolicy`.
    Format: `accessPolicies/{access_policy}`
  parent: Required. The parent of this `AccessPolicy` in the Cloud Resource
    Hierarchy. Currently immutable once created. Format:
    `organizations/{organization_id}`
  scopes: The scopes of the AccessPolicy. Scopes define which resources a
    policy can restrict and where its resources can be referenced. For
    example, policy A with `scopes=["folders/123"]` has the following
    behavior: - ServicePerimeter can only restrict projects within
    `folders/123`. - ServicePerimeter within policy A can only reference
    access levels defined within policy A. - Only one policy can include a
    given scope; thus, attempting to create a second policy which includes
    `folders/123` will result in an error. If no scopes are provided, then
    any resource within the organization can be restricted. Scopes cannot be
    modified after a policy is created. Policies can only have a single
    scope. Format: list of `folders/{folder_number}` or
    `projects/{project_number}`
  title: Required. Human readable title. Does not affect behavior.
r   r   r   r   Tr   rh   r   N)r   r   r   r   r   r   r   r  r   r  scopesr  r   r   r   r   rv   rv   =  s\    @ 
		q	!$			q	!$  #&  T2&



"%r   rv   c                   `    \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	Sr
g	)
0GoogleIdentityAccesscontextmanagerV1ApiOperationie  aV  Identification for an API Operation.

Fields:
  methodSelectors: API methods or permissions to allow. Method or permission
    must belong to the service specified by `service_name` field. A single
    MethodSelector entry with `*` specified for the `method` field will
    allow all methods AND permissions for the service specified in
    `service_name`.
  serviceName: The name of the API whose methods or permissions the
    IngressPolicy or EgressPolicy want to allow. A single ApiOperation with
    `service_name` field set to `*` will allow all methods AND permissions
    for all services.
2GoogleIdentityAccesscontextmanagerV1MethodSelectorr   Tr   r   r   N)r   r   r   r   r   r   r.   methodSelectorsr   serviceNamer   r   r   r   r  r  e  s0     **+_abmqr/%%a(+r   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  ix  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.CombiningFunctionValueValuesEnumi  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ORr   r   r   r    CombiningFunctionValueValuesEnumr    s    	 C	
Br   r  r   -GoogleIdentityAccesscontextmanagerV1Conditionr   Tr   r   N)r   r   r   r   r   r   r   r  r   combiningFunctionr.   
conditionsr   r   r   r   r  r  x  sD    *   ))*LaP%%&UWXcgh*r   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\R                  " SSSS9rSrg)r  i  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. Any non-empty field criteria evaluating
    to false will result in the Condition 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"`
  vpcNetworkSources: The request must originate from one of the provided VPC
    networks in Google Cloud. Cannot specify this field together with
    `ip_subnetworks`.
0GoogleIdentityAccesscontextmanagerV1DevicePolicyr   r   Tr   r   r   rh   ry   4GoogleIdentityAccesscontextmanagerV1VpcNetworkSourcerz   r   N)r   r   r   r   r   r   r.   devicePolicyr   ipSubnetworksr   rI   negateregionsrequiredAccessLevelsvpcNetworkSourcesr   r   r   r   r  r    s    #J ''(Z\]^,''D9-!!!d3'!!!$&!!!d3'"..q4@,,-cefquvr   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.
r   r   r   N)	r   r   r   r   r   r   r.   exprr   r   r   r   r  r    s     
			*$r   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  a  AllowedDeviceManagementLevelsValueListEntryValuesEnum enum type.

Values:
  MANAGEMENT_UNSPECIFIED: The device's management level is not specified
    or not known.
  NONE: The device is not managed.
  BASIC: Basic management is enabled, which is generally limited to
    monitoring and wiping the corporate account.
  COMPLETE: Complete device management. This includes more thorough
    monitoring and the ability to directly manage the device (such as
    remote wiping). This can be enabled through the Android Enterprise
    Platform.
r   r   r   r   r   N)
r   r   r   r   r   MANAGEMENT_UNSPECIFIEDNONEr   COMPLETEr   r   r   r   5AllowedDeviceManagementLevelsValueListEntryValuesEnumr    s     DEHr   r  c                   (    \ rS rSrSrSrSrSrSrSr	g)	bGoogleIdentityAccesscontextmanagerV1DevicePolicy.AllowedEncryptionStatusesValueListEntryValuesEnumi  a`  AllowedEncryptionStatusesValueListEntryValuesEnum enum type.

Values:
  ENCRYPTION_UNSPECIFIED: The encryption status of the device is not
    specified or not known.
  ENCRYPTION_UNSUPPORTED: The device does not support encryption.
  UNENCRYPTED: The device supports encryption, but is currently
    unencrypted.
  ENCRYPTED: The device is encrypted.
r   r   r   r   r   N)
r   r   r   r   r   ENCRYPTION_UNSPECIFIEDENCRYPTION_UNSUPPORTEDUNENCRYPTED	ENCRYPTEDr   r   r   r   1AllowedEncryptionStatusesValueListEntryValuesEnumr    s    	 KIr   r  r   Tr   r   0GoogleIdentityAccesscontextmanagerV1OsConstraintr   r   rh   ry   r   N)r   r   r   r   r   r   r   r  r  r   allowedDeviceManagementLevelsallowedEncryptionStatusesr.   osConstraintsrI   requireAdminApprovalrequireCorpOwnedrequireScreenlockr   r   r   r   r  r    s    8inn &)..   #,"5"56mop{  #A'112eghswx(()[]^imn-"//2++A.,,Q/r   r  c                       \ rS rSrSr " S S\R                  5      r " S S\R                  5      r\R                  " SSS	9r
\R                  " SS
5      r\R                  " SS5      r\R                  " SSSS	9rSrg).GoogleIdentityAccesscontextmanagerV1EgressFromi#  a  Defines the conditions under which an EgressPolicy matches a request.
Conditions based on information about the source of the request. Note that
if the destination of the request is also protected by a ServicePerimeter,
then that ServicePerimeter must have an IngressPolicy which allows access in
order for this request to succeed.

Enums:
  IdentityTypeValueValuesEnum: Specifies the type of identities that are
    allowed access to outside the perimeter. If left unspecified, then
    members of `identities` field will be allowed access.
  SourceRestrictionValueValuesEnum: Whether to enforce traffic restrictions
    based on `sources` field. If the `sources` fields is non-empty, then
    this field must be set to `SOURCE_RESTRICTION_ENABLED`.

Fields:
  identities: A list of identities that are allowed access through
    [EgressPolicy]. Identities can be an individual user, service account,
    Google group, or third-party identity. For third-party identity, only
    single identities are supported and other identity types are not
    supported. The `v1` identities that have the prefix `user`, `group`,
    `serviceAccount`, and `principal` in
    https://cloud.google.com/iam/docs/principal-identifiers#v1 are
    supported.
  identityType: Specifies the type of identities that are allowed access to
    outside the perimeter. If left unspecified, then members of `identities`
    field will be allowed access.
  sourceRestriction: Whether to enforce traffic restrictions based on
    `sources` field. If the `sources` fields is non-empty, then this field
    must be set to `SOURCE_RESTRICTION_ENABLED`.
  sources: Sources that this EgressPolicy authorizes access from. If this
    field is not empty, then `source_restriction` must be set to
    `SOURCE_RESTRICTION_ENABLED`.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	JGoogleIdentityAccesscontextmanagerV1EgressFrom.IdentityTypeValueValuesEnumiF  a  Specifies the type of identities that are allowed access to outside
the perimeter. If left unspecified, then members of `identities` field
will be allowed access.

Values:
  IDENTITY_TYPE_UNSPECIFIED: No blanket identity group specified.
  ANY_IDENTITY: Authorize access from all identities outside the
    perimeter.
  ANY_USER_ACCOUNT: Authorize access from all human users outside the
    perimeter.
  ANY_SERVICE_ACCOUNT: Authorize access from all service accounts outside
    the perimeter.
r   r   r   r   r   N
r   r   r   r   r   IDENTITY_TYPE_UNSPECIFIEDANY_IDENTITYANY_USER_ACCOUNTANY_SERVICE_ACCOUNTr   r   r   r   IdentityTypeValueValuesEnumr  F        !"Lr   r  c                   $    \ rS rSrSrSrSrSrSrg)OGoogleIdentityAccesscontextmanagerV1EgressFrom.SourceRestrictionValueValuesEnumiY  aV  Whether to enforce traffic restrictions based on `sources` field. If
the `sources` fields is non-empty, then this field must be set to
`SOURCE_RESTRICTION_ENABLED`.

Values:
  SOURCE_RESTRICTION_UNSPECIFIED: Enforcement preference unspecified, will
    not enforce traffic restrictions based on `sources` in EgressFrom.
  SOURCE_RESTRICTION_ENABLED: Enforcement preference enabled, traffic
    restrictions will be enforced based on `sources` in EgressFrom.
  SOURCE_RESTRICTION_DISABLED: Enforcement preference disabled, will not
    enforce traffic restrictions based on `sources` in EgressFrom.
r   r   r   r   N)	r   r   r   r   r   SOURCE_RESTRICTION_UNSPECIFIEDSOURCE_RESTRICTION_ENABLEDSOURCE_RESTRICTION_DISABLEDr   r   r   r    SourceRestrictionValueValuesEnumr  Y  s     &'"!""#r   r  r   Tr   r   r   0GoogleIdentityAccesscontextmanagerV1EgressSourcer   r   N)r   r   r   r   r   r   r   r  r  r   rN  r   identityTypesourceRestrictionr.   sourcesr   r   r   r   r  r  #  sz     DINN &$ $" $$Q6*$$%BAF,))*LaP""#UWXcgh'r   r  c                       \ rS rSrSr\R                  " SS5      r\R                  " SS5      r\R                  " S5      r
Srg	)
0GoogleIdentityAccesscontextmanagerV1EgressPolicyip  a9  Policy for egress from perimeter. EgressPolicies match requests based on
`egress_from` and `egress_to` stanzas. For an EgressPolicy to match, both
`egress_from` and `egress_to` stanzas must be matched. If an EgressPolicy
matches a request, the request is allowed to span the ServicePerimeter
boundary. For example, an EgressPolicy can be used to allow VMs on networks
within the ServicePerimeter to access a defined set of projects outside the
perimeter in certain contexts (e.g. to read data from a Cloud Storage bucket
or query against a BigQuery dataset). EgressPolicies are concerned with the
*resources* that a request relates as well as the API services and API
actions being used. They do not related to the direction of data movement.
More detailed documentation for this concept can be found in the
descriptions of EgressFrom and EgressTo.

Fields:
  egressFrom: Defines conditions on the source of a request causing this
    EgressPolicy to apply.
  egressTo: Defines the conditions on the ApiOperation and destination
    resources that cause this EgressPolicy to apply.
  title: Optional. Human-readable title for the egress rule. The title must
    be unique within the perimeter and can not exceed 100 characters. Within
    the access policy, the combined length of all rule titles must not
    exceed 240,000 characters.
r  r   ,GoogleIdentityAccesscontextmanagerV1EgressTor   r   r   N)r   r   r   r   r   r   r.   
egressFromegressTor   r  r   r   r   r   r  r  p  sA    0 %%&VXYZ*##$RTUV(



"%r   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)r  i  a)  The source that EgressPolicy authorizes access from inside the
ServicePerimeter to somewhere outside the ServicePerimeter boundaries.

Fields:
  accessLevel: An AccessLevel resource name that allows protected resources
    inside the ServicePerimeters to access outside the ServicePerimeter
    boundaries. AccessLevels listed must be in the same policy as this
    ServicePerimeter. Referencing a nonexistent AccessLevel will cause an
    error. If an AccessLevel name is not specified, only resources within
    the perimeter can be accessed through Google Cloud calls with request
    origins within the perimeter. Example:
    `accessPolicies/MY_POLICY/accessLevels/MY_LEVEL`. If a single `*` is
    specified for `access_level`, then all EgressSources will be allowed.
  resource: A Google Cloud resource from the service perimeter that you want
    to allow to access data outside the perimeter. This field supports only
    projects. The project format is `projects/{project_number}`. You can't
    use `*` in this field to allow all Google Cloud resources.
r   r   r   N
r   r   r   r   r   r   r   r   r   r   r   r   r   r  r    s)    & %%a(+""1%(r   r  c                       \ rS rSrSr\R                  " SSS9r\R                  " SSSS9r	\R                  " SSS9r
\R                  " S	SS9rS
rg)r  i  a  Defines the conditions under which an EgressPolicy matches a request.
Conditions are based on information about the ApiOperation intended to be
performed on the `resources` specified. Note that if the destination of the
request is also protected by a ServicePerimeter, then that ServicePerimeter
must have an IngressPolicy which allows access in order for this request to
succeed. The request must match `operations` AND `resources` fields in order
to be allowed egress out of the perimeter.

Fields:
  externalResources: A list of external resources that are allowed to be
    accessed. Only AWS and Azure resources are supported. For Amazon S3, the
    supported formats are s3://BUCKET_NAME, s3a://BUCKET_NAME, and
    s3n://BUCKET_NAME. For Azure Storage, the supported format is
    azure://myaccount.blob.core.windows.net/CONTAINER_NAME. A request
    matches if it contains an external resource in this list (Example:
    s3://bucket/path). Currently '*' is not allowed.
  operations: A list of ApiOperations allowed to be performed by the sources
    specified in the corresponding EgressFrom. A request matches if it uses
    an operation/service in this list.
  resources: A list of resources, currently only projects in the form
    `projects/`, that are allowed to be accessed by sources defined in the
    corresponding EgressFrom. A request matches if it contains a resource in
    this list. If `*` is specified for `resources`, then this EgressTo rule
    will authorize access to all resources outside the perimeter.
  roles: IAM roles that represent the set of operations that the sources
    specified in the corresponding EgressFrom. are allowed to perform in
    this ServicePerimeter.
r   Tr   r  r   r   r   r   N)r   r   r   r   r   r   r   externalResourcesr.   
operationsr  r'   r   r   r   r   r  r    sW    :  ++A=%%&XZ[fjk*##A5)


D
1%r   r  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	S
SS9rSrg)/GoogleIdentityAccesscontextmanagerV1IngressFromi  a  Defines the conditions under which an IngressPolicy matches a request.
Conditions are based on information about the source of the request. The
request must satisfy what is defined in `sources` AND identity related
fields in order to match.

Enums:
  IdentityTypeValueValuesEnum: Specifies the type of identities that are
    allowed access from outside the perimeter. If left unspecified, then
    members of `identities` field will be allowed access.

Fields:
  identities: A list of identities that are allowed access through
    [IngressPolicy]. Identities can be an individual user, service account,
    Google group, or third-party identity. For third-party identity, only
    single identities are supported and other identity types are not
    supported. The `v1` identities that have the prefix `user`, `group`,
    `serviceAccount`, and `principal` in
    https://cloud.google.com/iam/docs/principal-identifiers#v1 are
    supported.
  identityType: Specifies the type of identities that are allowed access
    from outside the perimeter. If left unspecified, then members of
    `identities` field will be allowed access.
  sources: Sources that this IngressPolicy authorizes access from.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	KGoogleIdentityAccesscontextmanagerV1IngressFrom.IdentityTypeValueValuesEnumi  a  Specifies the type of identities that are allowed access from outside
the perimeter. If left unspecified, then members of `identities` field
will be allowed access.

Values:
  IDENTITY_TYPE_UNSPECIFIED: No blanket identity group specified.
  ANY_IDENTITY: Authorize access from all identities outside the
    perimeter.
  ANY_USER_ACCOUNT: Authorize access from all human users outside the
    perimeter.
  ANY_SERVICE_ACCOUNT: Authorize access from all service accounts outside
    the perimeter.
r   r   r   r   r   Nr  r   r   r   r  r    r  r   r  r   Tr   r   1GoogleIdentityAccesscontextmanagerV1IngressSourcer   r   N)r   r   r   r   r   r   r   r  r   rN  r   r  r.   r  r   r   r   r   r  r    sU    2INN & $$Q6*$$%BAF,""#VXYdhi'r   r  c                       \ rS rSrSr\R                  " SS5      r\R                  " SS5      r\R                  " S5      r
Srg	)
1GoogleIdentityAccesscontextmanagerV1IngressPolicyi  a  Policy for ingress into ServicePerimeter. IngressPolicies match requests
based on `ingress_from` and `ingress_to` stanzas. For an ingress policy to
match, both the `ingress_from` and `ingress_to` stanzas must be matched. If
an IngressPolicy matches a request, the request is allowed through the
perimeter boundary from outside the perimeter. For example, access from the
internet can be allowed either based on an AccessLevel or, for traffic
hosted on Google Cloud, the project of the source network. For access from
private networks, using the project of the hosting network is required.
Individual ingress policies can be limited by restricting which services
and/or actions they match using the `ingress_to` field.

Fields:
  ingressFrom: Defines the conditions on the source of a request causing
    this IngressPolicy to apply.
  ingressTo: Defines the conditions on the ApiOperation and request
    destination that cause this IngressPolicy to apply.
  title: Optional. Human-readable title for the ingress rule. The title must
    be unique within the perimeter and can not exceed 100 characters. Within
    the access policy, the combined length of all rule titles must not
    exceed 240,000 characters.
r  r   -GoogleIdentityAccesscontextmanagerV1IngressTor   r   r   N)r   r   r   r   r   r   r.   ingressFrom	ingressTor   r  r   r   r   r   r  r    sA    , &&'XZ[\+$$%TVWX)



"%r   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)r  i  a  The source that IngressPolicy authorizes access from.

Fields:
  accessLevel: An AccessLevel resource name that allow resources within the
    ServicePerimeters to be accessed from the internet. AccessLevels listed
    must be in the same policy as this ServicePerimeter. Referencing a
    nonexistent AccessLevel will cause an 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`. If a single `*` is
    specified for `access_level`, then all IngressSources will be allowed.
  resource: A Google Cloud resource that is allowed to ingress the
    perimeter. Requests from these resources will be allowed to access
    perimeter data. Currently only projects and VPCs are allowed. Project
    format: `projects/{project_number}` VPC network format:
    `//compute.googleapis.com/projects/{PROJECT_ID}/global/networks/{NAME}`.
    The project may be in any Google Cloud organization, not just the
    organization that the perimeter is defined in. `*` is not allowed, the
    case of allowing all Google Cloud resources only is not supported.
r   r   r   Nr  r   r   r   r  r    s)    * %%a(+""1%(r   r  c                       \ rS rSrSr\R                  " SSSS9r\R                  " SSS9r	\R                  " SSS9r
S	rg
)r  i2  a  Defines the conditions under which an IngressPolicy matches a request.
Conditions are based on information about the ApiOperation intended to be
performed on the target resource of the request. The request must satisfy
what is defined in `operations` AND `resources` in order to match.

Fields:
  operations: A list of ApiOperations allowed to be performed by the sources
    specified in corresponding IngressFrom in this ServicePerimeter.
  resources: A list of resources, currently only projects in the form
    `projects/`, protected by this ServicePerimeter that are allowed to be
    accessed by sources defined in the corresponding IngressFrom. If a
    single `*` is specified, then access to all resources inside the
    perimeter are allowed.
  roles: IAM roles that represent the set of operations that the sources
    specified in the corresponding IngressFrom are allowed to perform in
    this ServicePerimeter.
r  r   Tr   r   r   r   N)r   r   r   r   r   r   r.   r  r   r  r'   r   r   r   r   r  r  2  sD    $ %%&XZ[fjk*##A5)


D
1%r   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)r  iJ  an  An allowed method or permission of a service specified in ApiOperation.

Fields:
  method: A valid method name for the corresponding `service_name` in
    ApiOperation. If `*` is used as the value for the `method`, then ALL
    methods and permissions are allowed.
  permission: A valid Cloud IAM permission for the corresponding
    `service_name` in ApiOperation.
r   r   r   N)
r   r   r   r   r   r   r   methodr  r   r   r   r   r  r  J  s)       #&$$Q'*r   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  iY  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.OsTypeValueValuesEnumij  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   rh   ry   r   N)r   r   r   r   r   OS_UNSPECIFIEDDESKTOP_MACDESKTOP_WINDOWSDESKTOP_LINUXDESKTOP_CHROME_OSANDROIDIOSr   r   r   r   OsTypeValueValuesEnumr  j  s-     NKOMG
Cr   r  r   r   r   r   N)r   r   r   r   r   r   r   r  r   minimumVersionr   osTyperI   requireVerifiedChromeOsr   r   r   r   r  r  Y  sM     inn * ((+.6:&%2215r   r  c                   h   \ rS rSrSr " S S\R                  5      r\R                  " S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 or VPC network 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
    or VPC network 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.
  etag: Optional. An opaque identifier for the current version of the
    `ServicePerimeter`. This identifier does not follow any specific format.
    If an etag is not provided, the operation will be performed as if a
    valid etag is provided.
  name: Identifier. Resource name for the `ServicePerimeter`. Format:
    `accessPolicies/{access_policy}/servicePerimeters/{service_perimeter}`.
    The `service_perimeter` component must begin with a letter, followed by
    alphanumeric characters or `_`. After you create a `ServicePerimeter`,
    you cannot change its `name`.
  perimeterType: Perimeter type indicator. A single project or VPC network
    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 or VPC network 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. When no value is specified,
    the perimeter uses this type.
  PERIMETER_TYPE_BRIDGE: Perimeter Bridge.
r   r   r   N)r   r   r   r   r   PERIMETER_TYPE_REGULARPERIMETER_TYPE_BRIDGEr   r   r   r   PerimeterTypeValueValuesEnumr    s    
 r   r  r   r   r   r   :GoogleIdentityAccesscontextmanagerV1ServicePerimeterConfigrh   ry   rz   r|   r   N)r   r   r   r   r   r   r   r  r   r  r  r   r   perimeterTyper.   specstatusr  rI   useExplicitDryRunSpecr   r   r   r   r   r     s    8tY^^  %%a(+			q	!$			q	!$%%&DaH-			 \^_	`$!!"^`ab&



"%#003r   r   c                       \ rS rSrSr\R                  " SSS9r\R                  " SSSS9r	\R                  " S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  i  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.
  egressPolicies: List of EgressPolicies to apply to the perimeter. A
    perimeter may have multiple EgressPolicies, each of which is evaluated
    separately. Access is granted if any EgressPolicy grants it. Must be
    empty for a perimeter bridge.
  ingressPolicies: List of IngressPolicies to apply to the perimeter. A
    perimeter may have multiple IngressPolicies, each of which is evaluated
    separately. Access is granted if any Ingress Policy grants it. Must be
    empty for a perimeter bridge.
  resources: A list of Google Cloud resources that are inside of the service
    perimeter. Currently only projects and VPCs are allowed. Project format:
    `projects/{project_number}` VPC network format:
    `//compute.googleapis.com/projects/{PROJECT_ID}/global/networks/{NAME}`.
  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   r  r   r   rh   9GoogleIdentityAccesscontextmanagerV1VpcAccessibleServicesry   r   N)r   r   r   r   r   r   r   accessLevelsr.   egressPoliciesingressPoliciesr  restrictedServicesvpcAccessibleServicesr   r   r   r   r  r    s    @ &&q48,))*\^_jno.**+^`alpq/##A5) ,,Q>#001lnopr   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. You can specify a
    list of individual services, as well as include the 'RESTRICTED-
    SERVICES' value, which automatically includes all of the services
    protected by the perimeter.
  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   allowedServicesrI   enableRestrictionr   r   r   r   r   r     s,     ))!d;/,,Q/r   r   c                   >    \ rS rSrSr\R                  " SS5      rSrg)r  i  zoThe originating network source in Google Cloud.

Fields:
  vpcSubnetwork: Sub-segment ranges of a VPC network.
1GoogleIdentityAccesscontextmanagerV1VpcSubNetworkr   r   N)	r   r   r   r   r   r   r.   vpcSubnetworkr   r   r   r   r  r    s     (()\^_`-r   r  c                   ^    \ rS rSrSr\R                  " S5      r\R                  " SSS9rSr	g)	r*  i  aC  Sub-segment ranges inside of a VPC Network.

Fields:
  network: Required. Network name. If the network is not part of the
    organization, the `compute.network.get` permission must be granted to
    the caller. Format: `//compute.googleapis.com/projects/{PROJECT_ID}/glob
    al/networks/{NETWORK_NAME}` Example:
    `//compute.googleapis.com/projects/my-project/global/networks/network-1`
  vpcIpSubnetworks: CIDR block IP subnetwork specification. The IP address
    must be an IPv4 address and can be a public or private IP address. 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. If empty, all IP addresses are allowed.
r   r   Tr   r   N)
r   r   r   r   r   r   r   networkvpcIpSubnetworksr   r   r   r   r*  r*    s,      !!!$'**1t<r   r*  c                       \ rS rSrSr\R                  " SS5      r\R                  " SSSS9r\R                  " S	S
SS9r	\R                  " S5      r\R                  " SSSS9rSrg)rH   i2  a  An analysis message to group the query and results.

Fields:
  analysisQuery: The analysis query.
  analysisResults: A list of IamPolicyAnalysisResult that matches the
    analysis query, or empty if no result is found.
  denyAnalysisResults: A list of DenyAnalysisResult, which contains access
    tuples in the analysis_results that are conducted deny policy analysis.
    The deny policy analysis will be conducted on max 1000 access tuples.
    For access tuples don't have deny policy analysis result populated, you
    can issue another query of that access tuple to get deny policy analysis
    result for it. This is only populated when
    IamPolicyAnalysisQuery.Options.include_deny_policy_analysis is true.
  fullyExplored: Represents whether all entries in the analysis_results have
    been fully explored to answer the query.
  nonCriticalErrors: A list of non-critical errors happened during the query
    handling.
r<   r   IamPolicyAnalysisResultr   Tr   r  r   r   r  rh   r   N)r   r   r   r   r   r   r.   r>   analysisResultsdenyAnalysisResultsrI   rJ   nonCriticalErrorsr   r   r   r   rH   rH   2  sp    & (()A1E-**+DaRVW/!../CQQUV((+-,,-EqSWXr   rH   c                   d    \ rS rSrSr\R                  " SS5      r\R                  " SS5      rSr	g)	r=   iM  zOutput configuration for export IAM policy analysis destination.

Fields:
  bigqueryDestination: Destination on BigQuery.
  gcsDestination: Destination on Cloud Storage.
r  r   rV  r   r   N
r   r   r   r   r   r   r.   bigqueryDestinationgcsDestinationr   r   r   r   r=   r=   M  s1     "../VXYZ))*LaP.r   r=   c                       \ rS rSrSr\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r	\R                  " S	S
5      r
\R                  " SS5      r\R                  " S5      rSrg)r<   iY  aT  IAM policy analysis query message.

Fields:
  accessSelector: Optional. Specifies roles or permissions for analysis.
    This is optional.
  conditionContext: Optional. The hypothetical context for IAM conditions
    evaluation.
  identitySelector: Optional. Specifies an identity for analysis.
  options: Optional. The query options.
  resourceSelector: Optional. Specifies a resource for analysis.
  scope: Required. The relative name of the root asset. Only resources and
    IAM policies within the scope will be analyzed. This can only be an
    organization number (such as "organizations/123"), a folder number (such
    as "folders/123"), a project ID (such as "projects/my-project-id"), or a
    project number (such as "projects/12345"). To know how to get
    organization ID, visit [here ](https://cloud.google.com/resource-
    manager/docs/creating-managing-
    organization#retrieving_your_organization_id). To know how to get folder
    or project ID, visit [here ](https://cloud.google.com/resource-
    manager/docs/creating-managing-
    folders#viewing_or_listing_folders_and_projects).
r$   r   r  r   IdentitySelectorr   Optionsr   ResourceSelectorrh   ry   r   N)r   r   r   r   r   r   r.   accessSelectorconditionContextidentitySelectoroptionsresourceSelectorr   r   r   r   r   r   r<   r<   Y  sz    . ))*:A>.++,>B++,>B""9a0'++,>B



"%r   r<   c                       \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	\R                  " S5      r\R                  " S	S
5      r\R                  " SS5      rSrg)r0  iy  a  IAM Policy analysis result, consisting of one IAM policy binding and
derived access control lists.

Fields:
  accessControlLists: The access control lists derived from the iam_binding
    that match or potentially match resource and access selectors specified
    in the request.
  attachedResourceFullName: The [full resource
    name](https://cloud.google.com/asset-inventory/docs/resource-name-
    format) of the resource to which the iam_binding policy attaches.
  fullyExplored: Represents whether all analyses on the iam_binding have
    successfully finished.
  iamBinding: The IAM policy binding under analysis.
  identityList: The identity list derived from members of the iam_binding
    that match or potentially match identity selector specified in the
    request.
r  r   Tr   r   r   r   r   r[  rh   r   N)r   r   r   r   r   r   r.   accessControlListsr   attachedResourceFullNamerI   rJ   
iamBindingidentityListr   r   r   r   r0  r0  y  sg    $ !--.SUVaef&2215((+-%%i3*''(H!L,r   r0  c                       \ rS rSrSr " S S\R                  5      r\R                  " S5      r	\R                  " SS5      rSrg)	r  i  aF  Represents the detailed state of an entity under analysis, such as a
resource, an identity or an access.

Enums:
  CodeValueValuesEnum: The Google standard error code that best describes
    the state. For example: - OK means the analysis on this entity has been
    successfully finished; - PERMISSION_DENIED means an access denied error
    is encountered; - DEADLINE_EXCEEDED means the analysis on this entity
    hasn't been started in time;

Fields:
  cause: The human-readable description of the cause of failure.
  code: The Google standard error code that best describes the state. For
    example: - OK means the analysis on this entity has been successfully
    finished; - PERMISSION_DENIED means an access denied error is
    encountered; - DEADLINE_EXCEEDED means the analysis on this entity
    hasn't been started in time;
c                   \    \ rS rSrSrSrSrSrSrSr	Sr
S	rS
rSrSrSrSrSrSrSrSrSrSrg)*IamPolicyAnalysisState.CodeValueValuesEnumi  a  The Google standard error code that best describes the state. For
example: - OK means the analysis on this entity has been successfully
finished; - PERMISSION_DENIED means an access denied error is encountered;
- DEADLINE_EXCEEDED means the analysis on this entity hasn't been started
in time;

Values:
  OK: Not an error; returned on success. HTTP Mapping: 200 OK
  CANCELLED: The operation was cancelled, typically by the caller. HTTP
    Mapping: 499 Client Closed Request
  UNKNOWN: Unknown error. For example, this error may be returned when a
    `Status` value received from another address space belongs to an error
    space that is not known in this address space. Also errors raised by
    APIs that do not return enough error information may be converted to
    this error. HTTP Mapping: 500 Internal Server Error
  INVALID_ARGUMENT: The client specified an invalid argument. Note that
    this differs from `FAILED_PRECONDITION`. `INVALID_ARGUMENT` indicates
    arguments that are problematic regardless of the state of the system
    (e.g., a malformed file name). HTTP Mapping: 400 Bad Request
  DEADLINE_EXCEEDED: The deadline expired before the operation could
    complete. For operations that change the state of the system, this
    error may be returned even if the operation has completed
    successfully. For example, a successful response from a server could
    have been delayed long enough for the deadline to expire. HTTP
    Mapping: 504 Gateway Timeout
  NOT_FOUND: Some requested entity (e.g., file or directory) was not
    found. Note to server developers: if a request is denied for an entire
    class of users, such as gradual feature rollout or undocumented
    allowlist, `NOT_FOUND` may be used. If a request is denied for some
    users within a class of users, such as user-based access control,
    `PERMISSION_DENIED` must be used. HTTP Mapping: 404 Not Found
  ALREADY_EXISTS: The entity that a client attempted to create (e.g., file
    or directory) already exists. HTTP Mapping: 409 Conflict
  PERMISSION_DENIED: The caller does not have permission to execute the
    specified operation. `PERMISSION_DENIED` must not be used for
    rejections caused by exhausting some resource (use
    `RESOURCE_EXHAUSTED` instead for those errors). `PERMISSION_DENIED`
    must not be used if the caller can not be identified (use
    `UNAUTHENTICATED` instead for those errors). This error code does not
    imply the request is valid or the requested entity exists or satisfies
    other pre-conditions. HTTP Mapping: 403 Forbidden
  UNAUTHENTICATED: The request does not have valid authentication
    credentials for the operation. HTTP Mapping: 401 Unauthorized
  RESOURCE_EXHAUSTED: Some resource has been exhausted, perhaps a per-user
    quota, or perhaps the entire file system is out of space. HTTP
    Mapping: 429 Too Many Requests
  FAILED_PRECONDITION: The operation was rejected because the system is
    not in a state required for the operation's execution. For example,
    the directory to be deleted is non-empty, an rmdir operation is
    applied to a non-directory, etc. Service implementors can use the
    following guidelines to decide between `FAILED_PRECONDITION`,
    `ABORTED`, and `UNAVAILABLE`: (a) Use `UNAVAILABLE` if the client can
    retry just the failing call. (b) Use `ABORTED` if the client should
    retry at a higher level. For example, when a client-specified test-
    and-set fails, indicating the client should restart a read-modify-
    write sequence. (c) Use `FAILED_PRECONDITION` if the client should not
    retry until the system state has been explicitly fixed. For example,
    if an "rmdir" fails because the directory is non-empty,
    `FAILED_PRECONDITION` should be returned since the client should not
    retry unless the files are deleted from the directory. HTTP Mapping:
    400 Bad Request
  ABORTED: The operation was aborted, typically due to a concurrency issue
    such as a sequencer check failure or transaction abort. See the
    guidelines above for deciding between `FAILED_PRECONDITION`,
    `ABORTED`, and `UNAVAILABLE`. HTTP Mapping: 409 Conflict
  OUT_OF_RANGE: The operation was attempted past the valid range. E.g.,
    seeking or reading past end-of-file. Unlike `INVALID_ARGUMENT`, this
    error indicates a problem that may be fixed if the system state
    changes. For example, a 32-bit file system will generate
    `INVALID_ARGUMENT` if asked to read at an offset that is not in the
    range [0,2^32-1], but it will generate `OUT_OF_RANGE` if asked to read
    from an offset past the current file size. There is a fair bit of
    overlap between `FAILED_PRECONDITION` and `OUT_OF_RANGE`. We recommend
    using `OUT_OF_RANGE` (the more specific error) when it applies so that
    callers who are iterating through a space can easily look for an
    `OUT_OF_RANGE` error to detect when they are done. HTTP Mapping: 400
    Bad Request
  UNIMPLEMENTED: The operation is not implemented or is not
    supported/enabled in this service. HTTP Mapping: 501 Not Implemented
  INTERNAL: Internal errors. This means that some invariants expected by
    the underlying system have been broken. This error code is reserved
    for serious errors. HTTP Mapping: 500 Internal Server Error
  UNAVAILABLE: The service is currently unavailable. This is most likely a
    transient condition, which can be corrected by retrying with a
    backoff. Note that it is not always safe to retry non-idempotent
    operations. See the guidelines above for deciding between
    `FAILED_PRECONDITION`, `ABORTED`, and `UNAVAILABLE`. HTTP Mapping: 503
    Service Unavailable
  DATA_LOSS: Unrecoverable data loss or corruption. HTTP Mapping: 500
    Internal Server Error
r   r   r   r   r   rh   ry   rz   r|   r~   r   r   r   r   r   r      r   N)r   r   r   r   r   OK	CANCELLEDUNKNOWNINVALID_ARGUMENTDEADLINE_EXCEEDED	NOT_FOUNDALREADY_EXISTSPERMISSION_DENIEDUNAUTHENTICATEDRESOURCE_EXHAUSTEDFAILED_PRECONDITIONABORTEDOUT_OF_RANGEUNIMPLEMENTEDINTERNALUNAVAILABLE	DATA_LOSSr   r   r   r   CodeValueValuesEnumrH    se    Zv 
BIGINOGLMHKIr   r[  r   r   r   N)r   r   r   r   r   r   r   r[  r   causer   coder   r   r   r   r  r    s?    &lINN l\ 


"%			2A	6$r   r  c                      \ rS rSrSr\R                  " 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Srg)IamPolicySearchResulti  a
  A result of IAM Policy search, containing information of an IAM policy.

Fields:
  assetType: The type of the resource associated with this IAM policy.
    Example: `compute.googleapis.com/Disk`. To search against the
    `asset_type`: * specify the `asset_types` field in your search request.
  explanation: Explanation about the IAM policy search result. It contains
    additional information to explain why the search result matches the
    query.
  folders: The folder(s) that the IAM policy belongs to, in the form of
    folders/{FOLDER_NUMBER}. This field is available when the IAM policy
    belongs to one or more folders. To search against `folders`: * use a
    field query. Example: `folders:(123 OR 456)` * use a free text query.
    Example: `123` * specify the `scope` field as this folder in your search
    request.
  organization: The organization that the IAM policy belongs to, in the form
    of organizations/{ORGANIZATION_NUMBER}. This field is available when the
    IAM policy belongs to an organization. To search against `organization`:
    * use a field query. Example: `organization:123` * use a free text
    query. Example: `123` * specify the `scope` field as this organization
    in your search request.
  policy: The IAM policy directly set on the given resource. Note that the
    original IAM policy can contain multiple bindings. This only contains
    the bindings that match the given query. For queries that don't contain
    a constrain on policies (e.g., an empty query), this contains all the
    bindings. To search against the `policy` bindings: * use a field query:
    - query by the policy contained members. Example: `policy:amy@gmail.com`
    - query by the policy contained roles. Example:
    `policy:roles/compute.admin` - query by the policy contained roles'
    included permissions. Example:
    `policy.role.permissions:compute.instances.create`
  project: The project that the associated Google Cloud resource belongs to,
    in the form of projects/{PROJECT_NUMBER}. If an IAM policy is set on a
    resource (like VM instance, Cloud Storage bucket), the project field
    will indicate the project that contains the resource. If an IAM policy
    is set on a folder or organization, this field will be empty. To search
    against the `project`: * specify the `scope` field as this project in
    your search request.
  resource: The full resource name of the resource associated with this IAM
    policy. Example: `//compute.googleapis.com/projects/my_project_123/zones
    /zone1/instances/instance1`. See [Cloud Asset Inventory Resource Name
    Format](https://cloud.google.com/asset-inventory/docs/resource-name-
    format) for more information. To search against the `resource`: * use a
    field query. Example: `resource:organizations/123`
r   r  r   r   Tr   r   rx   rh   ry   rz   r   N)r   r   r   r   r   r   r   r   r.   explanationr  r    r  r  r   r   r   r   r   r_  r_    s    ,\ ##A&)&&}a8+!!!d3'&&q),!!(A.&!!!$'""1%(r   r_  c                   <    \ rS rSrSr\R                  " S5      rSrg)r9  iQ  am  Specifies an identity for which to determine resource access, based on
roles assigned either directly to them or to the groups they belong to,
directly or indirectly.

Fields:
  identity: Required. The identity appear in the form of principals in [IAM
    policy binding](https://cloud.google.com/iam/reference/rest/v1/Binding).
    The examples of supported forms are: "user:mike@example.com",
    "group:admins@example.com", "domain:google.com", "serviceAccount:my-
    project-id@appspot.gserviceaccount.com". Notice that wildcard characters
    (such as * and ?) are not supported. You must give a specific identity.
r   r   N)	r   r   r   r   r   r   r   rI  r   r   r   r   r9  r9  Q  s     ""1%(r   r9  c                   :    \ rS rSrSr\R                  " SSS9rSrg)r  ib  zIncluded subscription IDs.

Fields:
  includedSubscriptionIds: Optional. List of subscriptions where the data
    will be collected from. This list should be mutually exclusive with
    excluded_subscription_ids.
r   Tr   r   N)	r   r   r   r   r   r   r   r  r   r   r   r   r  r  b  r  r   r  c                   >    \ rS rSrSr\R                  " SS5      rSrg)r?  in  z`Request to ingest an other-cloud asset.

Fields:
  asset: The other-cloud asset to be ingested.
OtherCloudAssetEventr   r   N)	r   r   r   r   r   r   r.   rr  r   r   r   r   r?  r?  n  s     
 
 !7
;%r   r?  c                   <    \ rS rSrSr\R                  " S5      rSrg)IngestAssetResponseix  zResponse of ingesting an other-cloud asset.

Fields:
  name: It is the original name of the resource. For AWS assets, use
    [ARN](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference-
    arns.html)
r   r   Nr3  r   r   r   rf  rf  x  s     
		q	!$r   rf  c                   H   \ rS rSrSr " S S\R                  5      r " S S\R                  5      r\R                  " S5      r
\R                  " SS5      r\R                  " S	5      r\R                  " S
5      r\R                  " S5      r\R                  " SS5      rSrg)r+   i  ar  For AWS, this includes the details about an invalid Collector account.
For Azure, this includes the details about an missing required role type.

Enums:
  AccountStatusCategoryValueValuesEnum: Optional. NOTE: Deprecated The
    account status category.
  StatusCategoryValueValuesEnum: Optional. The status category.

Fields:
  accountId: Required. The account id of the invalid AWS Collector account.
    This is only used for AWS.
  accountStatusCategory: Optional. NOTE: Deprecated The account status
    category.
  cause: Optional. The detailed reason for the invalidity.
  role: Optional. For AWS, this is the invalid Collector Role name of the
    invalid AWS account. For Azure, this is the missing role types. It will
    be either "Azure Role" or "Microsoft Entra Role".
  status: Optional. The invalidity status. For AWS, it should be either
    AWS_FAILED_TO_ASSUME_COLLECTOR_ROLE or
    AWS_COLLECTOR_ROLE_POLICY_MISSING_REQUIRED_PERMISSION. For Azure, it
    should be either AZURE_FAILED_TO_ASSUME_MANAGED_IDENTITY or
    AZURE_MANAGED_IDENTITY_MISSING_REQUIRED_PERMISSION.
  statusCategory: Optional. The status category.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	<InvalidCollectorAccount.AccountStatusCategoryValueValuesEnumi  a  Optional. NOTE: Deprecated The account status category.

Values:
  ACCOUNT_STATUS_CATEGORY_UNSPECIFIED: Unknown.
  ACCOUNT_INOPERATIVE: The collector account is inoperative, meaning it
    cannot be used to perform any actions. This is the case when the
    fundamental setup of the connection is broken.
  ACCOUNT_MISSING_EXPECTED_PERMISSIONS: The collector account is missing
    required permissions, including the basic permission set and the
    permissions required for opted-in features.
  ACCOUNT_MISSING_OPTIONAL_PERMISSIONS: The collector account has all
    required permissions and is missing permissions required by available
    and not yet opted-in features.
r   r   r   r   r   N)
r   r   r   r   r   #ACCOUNT_STATUS_CATEGORY_UNSPECIFIEDACCOUNT_INOPERATIVE$ACCOUNT_MISSING_EXPECTED_PERMISSIONS$ACCOUNT_MISSING_OPTIONAL_PERMISSIONSr   r   r   r   $AccountStatusCategoryValueValuesEnumri    s!     +,'+,(+,(r   rn  c                   (    \ rS rSrSrSrSrSrSrSr	g)	5InvalidCollectorAccount.StatusCategoryValueValuesEnumi  a  Optional. The status category.

Values:
  STATUS_CATEGORY_UNSPECIFIED: Unknown.
  INOPERATIVE: The AWS collector account or Azure/Microsoft Entra Role is
    inoperative, meaning it cannot be used to perform any actions. This is
    the case when the fundamental setup of the connection is broken.
  MISSING_EXPECTED_PERMISSIONS: The AWS collector account or
    Azure/Microsoft Entra Role is missing required permissions, including
    the basic permission set and the permissions required for opted-in
    features.
  MISSING_OPTIONAL_PERMISSIONS: The AWS collector account or
    Azure/Microsoft Entra Role has all required permissions and is missing
    permissions required by available and not yet opted-in features.
r   r   r   r   r   N)
r   r   r   r   r   STATUS_CATEGORY_UNSPECIFIEDINOPERATIVEMISSING_EXPECTED_PERMISSIONSMISSING_OPTIONAL_PERMISSIONSr   r   r   r   StatusCategoryValueValuesEnumrp    s      #$K#$ #$ r   ru  r   r   r   r   rh   ry   r   N)r   r   r   r   r   r   r   rn  ru  r   	accountIdr   accountStatusCategoryr\  r   r  statusCategoryr   r   r   r   r+   r+     s    2-Y^^ -(%inn %* ##A&)#--.TVWX



"%			q	!$  #&&&'FJ.r   r+   c                       \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " SS5      r\R                  " S5      r\R                  " SS	5      r\R                  " S
5      rSrg)r}   i  a  This API resource represents the available inventory data for a Compute
Engine virtual machine (VM) instance at a given point in time. You can use
this API resource to determine the inventory data of your VM. For more
information, see [Information provided by OS inventory
management](https://cloud.google.com/compute/docs/instances/os-inventory-
management#data-collected).

Messages:
  ItemsValue: Inventory items related to the VM keyed by an opaque unique
    identifier for each inventory item. The identifier is unique to each
    distinct and addressable inventory item and will change, when there is a
    new package version.

Fields:
  items: Inventory items related to the VM keyed by an opaque unique
    identifier for each inventory item. The identifier is unique to each
    distinct and addressable inventory item and will change, when there is a
    new package version.
  name: Output only. The `Inventory` API resource name. Format: `projects/{p
    roject_number}/locations/{location}/instances/{instance_id}/inventory`
  osInfo: Base level operating system information for the VM.
  updateTime: Output only. Timestamp of the last reported inventory for the
    VM.
rn  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
Inventory.ItemsValuei  az  Inventory items related to the VM keyed by an opaque unique identifier
for each inventory item. The identifier is unique to each distinct and
addressable inventory item and will change, when there is a new package
version.

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

Fields:
  additionalProperties: Additional properties of type ItemsValue
c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)'Inventory.ItemsValue.AdditionalPropertyi  z|An additional property for a ItemsValue object.

Fields:
  key: Name of the additional property.
  value: A Item attribute.
r   Itemr   r   Nr  r   r   r   ru  r}    s+    
 !!!$c$$VQ/er   ru  r   Tr   r   Nrv  r   r   r   
ItemsValuer{    s2    
	0Y.. 	0 %112FTXYr   r  r   r   OsInfor   r   r   N)r   r   r   r   r   r   r{  r   rw  r  r.   itemsr   r   osInfor   r   r   r   r   r}   r}     s}    2 !!"89Z9$$ Z :Z4 
 
 q
1%			q	!$!!(A.&$$Q'*r   r}   c                   p   \ 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
5      r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R                  " S5      rSrg)r~  i
  a  A single piece of inventory on a VM.

Enums:
  OriginTypeValueValuesEnum: The origin of this inventory item.
  TypeValueValuesEnum: The specific type of inventory, correlating to its
    specific details.

Fields:
  availablePackage: Software package available to be installed on the VM
    instance.
  createTime: When this inventory item was first detected.
  id: Identifier for this item, unique across items for this VM.
  installedPackage: Software package present on the VM instance.
  originType: The origin of this inventory item.
  type: The specific type of inventory, correlating to its specific details.
  updateTime: When this inventory item was last modified.
c                        \ rS rSrSrSrSrSrg)Item.OriginTypeValueValuesEnumi  zThe origin of this inventory item.

Values:
  ORIGIN_TYPE_UNSPECIFIED: Invalid. An origin type must be specified.
  INVENTORY_REPORT: This inventory item was discovered as the result of
    the agent reporting inventory via the reporting API.
r   r   r   N)r   r   r   r   r   ORIGIN_TYPE_UNSPECIFIEDINVENTORY_REPORTr   r   r   r   OriginTypeValueValuesEnumr    s      r   r  c                   $    \ rS rSrSrSrSrSrSrg)Item.TypeValueValuesEnumi(  a)  The specific type of inventory, correlating to its specific details.

Values:
  TYPE_UNSPECIFIED: Invalid. A type must be specified.
  INSTALLED_PACKAGE: This represents a package that is installed on the
    VM.
  AVAILABLE_PACKAGE: This represents an update that is available for a
    package.
r   r   r   r   N)	r   r   r   r   r   TYPE_UNSPECIFIEDINSTALLED_PACKAGEAVAILABLE_PACKAGEr   r   r   r   TypeValueValuesEnumr  (  s     r   r  SoftwarePackager   r   r   r   rh   ry   rz   r   N)r   r   r   r   r   r   r   r  r  r.   availablePackager   r8   idinstalledPackager   
originTyper|  r   r   r   r   r   r~  r~  
  s    $	).. 	INN  ++,=qA$$Q'*Q"++,=qA""#>B*			2A	6$$$Q'*r   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
)ListAssetsResponsei?  a  ListAssets response.

Fields:
  assets: Assets.
  nextPageToken: Token to retrieve the next page of results. It expires 72
    hours after the page token for the first page is generated. Set to empty
    if there are no remaining results.
  readTime: Time the snapshot was taken.
rt   r   Tr   r   r   r   N)r   r   r   r   r   r   r.   r   r   rX   r  r   r   r   r   r  r  ?  s=     !!'1t<&''*-""1%(r   r  c                   <    \ rS rSrSr\R                  " SSSS9rSrg)	ListFeedsResponseiO  z?A ListFeedsResponse object.

Fields:
  feeds: A list of feeds.
r  r   Tr   r   N)	r   r   r   r   r   r   r.   feedsr   r   r   r   r  r  O  s     
 
 T
:%r   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
!ListOtherCloudConnectionsResponseiY  a*  Response to list other-cloud connections.

Fields:
  nextPageToken: A token, which can be sent as `page_token` to retrieve the
    next page. If this field is omitted, there are no subsequent pages.
  otherCloudConnections: The other-cloud connections from the specified
    parent or all parents.
r   rF  r   Tr   r   N)r   r   r   r   r   r   r   rX   r.   otherCloudConnectionsr   r   r   r   r  r  Y  s0     ''*-#001GUYZr   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
ListSavedQueriesResponseig  zResponse of listing saved queries.

Fields:
  nextPageToken: A token, which can be sent as `page_token` to retrieve the
    next page. If this field is omitted, there are no subsequent pages.
  savedQueries: A list of savedQueries.
r   rZ  r   Tr   r   N)r   r   r   r   r   r   r   rX   r.   savedQueriesr   r   r   r   r  r  g  s-     ''*-''a$G,r   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)r   it  aZ  Additional information for management group from Azure

Fields:
  managementGroupDisplayName: The Azure Management Group
    [displayName](https://learn.microsoft.com/en-
    us/rest/api/managementgroups/management-groups/list?view=rest-
    managementgroups-2020-05-01&tabs=HTTP#examples) E.g.: Test Management
    Group
  managementGroupResourceId: The Azure Management Group ID
    (https://learn.microsoft.com/en-us/rest/api/managementgroups/management-
    groups/list?view=rest-managementgroups-2020-05-01&tabs=HTTP#examples)
    E.g.: /providers/Microsoft.Management/managementGroups/group-name
r   r   r   N)
r   r   r   r   r   r   r   managementGroupDisplayNamemanagementGroupResourceIdr   r   r   r   r   r   t  s+      )44Q7'33A6r   r   c                       \ rS rSrSr\R                  " SS5      r\R                  " S5      r	\R                  " SS5      r
Srg	)
rP   i  a  A message to group the analysis information.

Fields:
  analysis: Analysis result of moving the target resource.
  displayName: The user friendly display name of the analysis. E.g. IAM,
    organization policy etc.
  error: Description of error encountered when performing the analysis.
MoveAnalysisResultr   r   Statusr   r   N)r   r   r   r   r   r   r.   analysisr   r0  errorr   r   r   r   rP   rP     s>     ##$8!<(%%a(+

 
 1
-%r   rP   c                   `    \ rS rSrSr\R                  " SSSS9r\R                  " SSSS9rSr	g	)
r  i  a  An analysis result including blockers and warnings.

Fields:
  blockers: Blocking information that would prevent the target resource from
    moving to the specified destination at runtime.
  warnings: Warning information indicating that moving the target resource
    to the specified destination might be unsafe. This can include important
    policy information and configuration changes, but will not block moves
    at runtime.

MoveImpactr   Tr   r   r   N)
r   r   r   r   r   r   r.   blockerswarningsr   r   r   r   r  r    s1    	 ##L!dC(##L!dC(r   r  c                   <    \ rS rSrSr\R                  " S5      rSrg)r  i  zA message to group impacts of moving the target resource.

Fields:
  detail: User friendly impact detail in a free form message.
r   r   N)	r   r   r   r   r   r   r   detailr   r   r   r   r  r    s       #&r   r  c                   z   \ 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5      r\R                  " S	S
5      r\R                  " SS5      r\R                   " S5      r\R                  " SS5      rSrg)	Operationi  a  This resource represents a long-running operation that is the result of
a network API call.

Messages:
  MetadataValue: Service-specific metadata associated with the operation. It
    typically contains progress information and common metadata such as
    create time. Some services might not provide such metadata. Any method
    that returns a long-running operation should document the metadata type,
    if any.
  ResponseValue: The normal, successful response of the operation. If the
    original method returns no data on success, such as `Delete`, the
    response is `google.protobuf.Empty`. If the original method is standard
    `Get`/`Create`/`Update`, the response should be the resource. For other
    methods, the response should have the type `XxxResponse`, where `Xxx` is
    the original method name. For example, if the original method name is
    `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`.

Fields:
  done: If the value is `false`, it means the operation is still in
    progress. If `true`, the operation is completed, and either `error` or
    `response` is available.
  error: The error result of the operation in case of failure or
    cancellation.
  metadata: Service-specific metadata associated with the operation. It
    typically contains progress information and common metadata such as
    create time. Some services might not provide such metadata. Any method
    that returns a long-running operation should document the metadata type,
    if any.
  name: The server-assigned name, which is only unique within the same
    service that originally returns it. If you use the default HTTP mapping,
    the `name` should be a resource name ending with
    `operations/{unique_id}`.
  response: The normal, successful response of the operation. If the
    original method returns no data on success, such as `Delete`, the
    response is `google.protobuf.Empty`. If the original method is standard
    `Get`/`Create`/`Update`, the response should be the resource. For other
    methods, the response should have the type `XxxResponse`, where `Xxx` is
    the original method name. For example, if the original method name is
    `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`.
rn  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
Operation.MetadataValuei  a  Service-specific metadata associated with the operation. It typically
contains progress information and common metadata such as create time.
Some services might not provide such metadata. Any method that returns a
long-running operation should document the metadata type, if any.

Messages:
  AdditionalProperty: An additional property for a MetadataValue 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)*Operation.MetadataValue.AdditionalPropertyi  zAn additional property for a MetadataValue object.

Fields:
  key: Name of the additional property.
  value: A extra_types.JsonValue attribute.
r   r  r   r   Nr  r   r   r   ru  r    r  r   ru  r   Tr   r   Nrv  r   r   r   MetadataValuer    s4    	AY.. 	A %112FTXYr   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	)
Operation.ResponseValuei  a  The normal, successful response of the operation. If the original
method returns no data on success, such as `Delete`, the response is
`google.protobuf.Empty`. If the original method is standard
`Get`/`Create`/`Update`, the response should be the resource. For other
methods, the response should have the type `XxxResponse`, where `Xxx` is
the original method name. For example, if the original method name is
`TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`.

Messages:
  AdditionalProperty: An additional property for a ResponseValue 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)*Operation.ResponseValue.AdditionalPropertyi  zAn additional property for a ResponseValue object.

Fields:
  key: Name of the additional property.
  value: A extra_types.JsonValue attribute.
r   r  r   r   Nr  r   r   r   ru  r    r  r   ru  r   Tr   r   Nrv  r   r   r   ResponseValuer    4     	AY.. 	A %112FTXYr   r  r   r  r   r   r   rh   r   N)r   r   r   r   r   r   r{  r   rw  r  r  rI   doner.   r  metadatar   r   responser   r   r   r   r  r    s    'R !!"89Zi'' Z :Z6 !!"89Zi'' Z :Z< 
			"$

 
 1
-%##OQ7(			q	!$##OQ7(r   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
\R                  " S5      r\R                  " S5      r\R                  " S	5      rS
rg)r:  i  ap  Contains query options.

Fields:
  analyzeServiceAccountImpersonation: Optional. If true, the response will
    include access analysis from identities to resources via service account
    impersonation. This is a very expensive operation, because many derived
    queries will be executed. We highly recommend you use
    AssetService.AnalyzeIamPolicyLongrunning RPC instead. For example, if
    the request analyzes for which resources user A has permission P, and
    there's an IAM policy states user A has
    iam.serviceAccounts.getAccessToken permission to a service account SA,
    and there's another IAM policy states service account SA has permission
    P to a Google Cloud folder F, then user A potentially has access to the
    Google Cloud folder F. And those advanced analysis results will be
    included in
    AnalyzeIamPolicyResponse.service_account_impersonation_analysis. Another
    example, if the request analyzes for who has permission P to a Google
    Cloud folder F, and there's an IAM policy states user A has
    iam.serviceAccounts.actAs permission to a service account SA, and
    there's another IAM policy states service account SA has permission P to
    the Google Cloud folder F, then user A potentially has access to the
    Google Cloud folder F. And those advanced analysis results will be
    included in
    AnalyzeIamPolicyResponse.service_account_impersonation_analysis. Only
    the following permissions are considered in this analysis: *
    `iam.serviceAccounts.actAs` * `iam.serviceAccounts.signBlob` *
    `iam.serviceAccounts.signJwt` * `iam.serviceAccounts.getAccessToken` *
    `iam.serviceAccounts.getOpenIdToken` *
    `iam.serviceAccounts.implicitDelegation` Default is false.
  expandGroups: Optional. If true, the identities section of the result will
    expand any Google groups appearing in an IAM policy binding. If
    IamPolicyAnalysisQuery.identity_selector is specified, the identity in
    the result will be determined by the selector, and this flag is not
    allowed to set. If true, the default max expansion per group is 1000 for
    AssetService.AnalyzeIamPolicy][]. Default is false.
  expandResources: Optional. If true and
    IamPolicyAnalysisQuery.resource_selector is not specified, the resource
    section of the result will expand any resource attached to an IAM policy
    to include resources lower in the resource hierarchy. For example, if
    the request analyzes for which resources user A has permission P, and
    the results include an IAM policy with P on a Google Cloud folder, the
    results will also include resources in that folder with permission P. If
    true and IamPolicyAnalysisQuery.resource_selector is specified, the
    resource section of the result will expand the specified resource to
    include resources lower in the resource hierarchy. Only project or lower
    resources are supported. Folder and organization resources cannot be
    used together with this option. For example, if the request analyzes for
    which users have permission P on a Google Cloud project with this option
    enabled, the results will include all users who have permission P on
    that project or any lower resource. If true, the default max expansion
    per resource is 1000 for AssetService.AnalyzeIamPolicy][] and 100000 for
    AssetService.AnalyzeIamPolicyLongrunning][]. Default is false.
  expandRoles: Optional. If true, the access section of result will expand
    any roles appearing in IAM policy bindings to include their permissions.
    If IamPolicyAnalysisQuery.access_selector is specified, the access
    section of the result will be determined by the selector, and this flag
    is not allowed to set. Default is false.
  includeDenyPolicyAnalysis: Optional. If true, the response includes deny
    policy analysis results for access tuples. The deny policy analysis will
    be conducted on max 1000 access tuples. For access tuples don't have
    deny policy analysis result populated, you can issue another query of
    that access tuple to get deny policy analysis result for it. Default is
    false.
  outputGroupEdges: Optional. If true, the result will output the relevant
    membership relationships between groups and other groups, and between
    groups and principals. Default is false.
  outputResourceEdges: Optional. If true, the result will output the
    relevant parent/child relationships between resources. Default is false.
r   r   r   r   rh   ry   rz   r   N)r   r   r   r   r   r   rI   "analyzeServiceAccountImpersonationexpandGroupsexpandResourcesexpandRolesincludeDenyPolicyAnalysisoutputGroupEdgesoutputResourceEdgesr   r   r   r   r:  r:    s    DL (1'='=a'@$''*,**1-/&&q)+'44Q7++A.!..q1r   r:  c                       \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	\R                  " S5      r
\R                  " SS	SS9r\R                  " S
5      rSrg)rV   il  a.  The organization policy result to the query.

Fields:
  consolidatedPolicy: The consolidated organization policy for the analyzed
    resource. The consolidated organization policy is computed by merging
    and evaluating policy_bundle. The evaluation will respect the
    organization policy [hierarchy rules](https://cloud.google.com/resource-
    manager/docs/organization-policy/understanding-hierarchy).
  folders: The folder(s) that this consolidated policy belongs to, in the
    format of folders/{FOLDER_NUMBER}. This field is available when the
    consolidated policy belongs (directly or cascadingly) to one or more
    folders.
  organization: The organization that this consolidated policy belongs to,
    in the format of organizations/{ORGANIZATION_NUMBER}. This field is
    available when the consolidated policy belongs (directly or cascadingly)
    to an organization.
  policyBundle: The ordered list of all organization policies from the
    consolidated_policy.attached_resource. to the scope specified in the
    request. If the constraint is defined with default policy, it will also
    appear in the list.
  project: The project that this consolidated policy belongs to, in the
    format of projects/{PROJECT_NUMBER}. This field is available when the
    consolidated policy belongs to a project.
re   r   r   Tr   r   r   rh   r   N)r   r   r   r   r   r   r.   r  r   r  r    r  r  r   r   r   r   rV   rV   l  sd    2 !--.A1E!!!d3'&&q),''(;QN,!!!$'r   rV   c                   8   \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S5      r	\R                  " S5      r
\R                  " S5      r\R                  " S5      r\R                  " S	5      r\R                  " S
5      rSrg)r  i  ai  Operating system information for the VM.

Fields:
  architecture: The system architecture of the operating system.
  hostname: The VM hostname.
  kernelRelease: The kernel release of the operating system.
  kernelVersion: The kernel version of the operating system.
  longName: The operating system long name. For example 'Debian GNU/Linux 9'
    or 'Microsoft Window Server 2019 Datacenter'.
  osconfigAgentVersion: The current version of the OS Config agent running
    on the VM.
  shortName: The operating system short name. For example, 'windows' or
    'debian'.
  version: The version of the operating system.
r   r   r   r   rh   ry   rz   r|   r   N)r   r   r   r   r   r   r   architecturehostnamekernelReleasekernelVersionlongNameosconfigAgentVersion	shortNamer  r   r   r   r   r  r    s      &&q),""1%(''*-''*-""1%("..q1##A&)!!!$'r   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S	5      r\R                  " S
5      r\R                  " SSSS9r\R                  " S5      r\R                  " S5      r\R                  " SS5      r\R                  " S5      r\R                  " SS5      r\R(                  " SS5      rSrg)rd  i  a  The asset event for other-cloud asset ingestion.

Enums:
  StateValueValuesEnum: The state of this asset.

Fields:
  assetUri: The URI that an end-user should be able to call GET to get data
    directly from the publishers' API.
  awsInfo: For an asset fetched from AWS.
  azureInfo: For an asset fetched from Azure.
  connection: The full name of the Other-Cloud Connection resource used to
    collect this asset in the format of
    `//cloudasset.googleapis.com/organizations//OtherCloudConnections/`
    E.g.: For AWS:
    cloudasset.googleapis.com/organizations/123/otherCloudConnections/aws
    For Azure
    cloudasset.googleapis.com/organizations/123/otherCloudConnections/azure
  contents: A representation of other-cloud asset events.
  createTime: A timestamp to represent the time when the asset was created.
    For other-cloud assets, this is optional.
  eventTime: A timestamp to represent the latest time we observe (collect)
    this resource.
  id: The identifier of this asset.
  location: The location of this asset. For AWS assets: For AWS regions, it
    is the region name listed in
    https://docs.aws.amazon.com/general/latest/gr/rande.html#regional-
    endpoints For AWS China, see `Learn more` section in
    https://docs.aws.amazon.com/general/latest/gr/rande.html#learn-more For
    AWS Gov, see GovCloud regions in:
    https://docs.aws.amazon.com/general/latest/gr/rande.html#regional-
    endpoints For Azure assets, it is the location id for regions listed in
    https://azure.microsoft.com/en-us/explore/global-
    infrastructure/geographies/#geographies. An example is "eastus2". Use az
    account list-locations | grep "name" to list all location ids available
    for the subscription of the logged in account.
  parent: The immediate parent of this asset, and it must be other-cloud
    asset. Otherwise, empty. Note: for AWS, we will populate this field only
    when the parent can be extracted from this asset's ARN.
  state: The state of this asset.
c                   $    \ rS rSrSrSrSrSrSrg))OtherCloudAssetEvent.StateValueValuesEnumi  zThe state of this asset.

Values:
  STATE_UNSPECIFIED: State is not applicable for the current asset.
  EXIST: Asset exists.
  DELETED: Asset was deleted.
r   r   r   r   N)	r   r   r   r   r   STATE_UNSPECIFIEDEXISTDELETEDr   r   r   r   StateValueValuesEnumr    s     EGr   r  r   r   r   r   r   r   r  rh   Tr   ry   rz   OtherCloudAssetIdr|   r~   r   r   r   N)r   r   r   r   r   r   r   r  r   assetUrir.   awsInfo	azureInfo
connectioncontentsr8   	eventTimer  r  r  r   stater   r   r   r   rd  rd    s    'R
Y^^ 
 ""1%(""9a0'$$[!4)$$Q'*##Iq4@($$Q'*##A&)115"""1%(!!"5r:&


4b
9%r   rd  c                       \ 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S
rg)r  i  a&  An identifier of an other-cloud asset. All fields are case sensitive,
unless explicitly noted.

Enums:
  DataSourceProviderValueValuesEnum: The data source provider of this asset.

Fields:
  assetName: The name of this asset in the data source provider. It is the
    original name of the resource. The AWS asset name follows [Amazon
    Resource Name (ARN)
    format](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference-
    arns.html) The Microsoft Azure asset name follows [Microsoft Azure
    Resource Id format](https://learn.microsoft.com/en-us/azure/azure-
    resource-manager/templates/template-functions-resource#resourceid)
  assetType: The type of this asset.
  dataCollector: The data collector party collecting the asset.
  dataSourceProvider: The data source provider of this asset.
c                   $    \ rS rSrSrSrSrSrSrg)3OtherCloudAssetId.DataSourceProviderValueValuesEnumi  zThe data source provider of this asset.

Values:
  PROVIDER_UNSPECIFIED: The unspecified value for data source provider.
  AMAZON_WEB_SERVICES: The value for AWS.
  MICROSOFT_AZURE: The value for Microsoft Azure.
r   r   r   r   N)	r   r   r   r   r   PROVIDER_UNSPECIFIEDAMAZON_WEB_SERVICESMICROSOFT_AZUREr   r   r   r   !DataSourceProviderValueValuesEnumr    s     Or   r  r   r   r  r   r   r   N)r   r   r   r   r   r   r   r  r   	assetNamer   r.   dataCollectorr   dataSourceProviderr   r   r   r   r  r    s`    &
).. 
 ##A&)##A&)((!<- **+NPQRr   r  c                      \ rS rSrSr " S S\R                  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\R                  " SSSS9r\R                  " S5      r\R                  " S5      r\R                  " SSSS9rSrg)rF  i  a2  An Other-Cloud Connection is a set of settings to allow Google Cloud to
connect to an other-cloud provider(such as AWS, Azure, etc.) to collect
their asset config data for Google Cloud products' use.

Enums:
  ConnectionTypeValueValuesEnum: Required. The other-cloud connection type.

Fields:
  collectAwsAssetSetting: AWS connection setting.
  collectAzureAssetSetting: Azure connection setting.
  connectionType: Required. The other-cloud connection type.
  createTime: Output only. The absolute point in time when the other-cloud
    connection was created.
  description: Optional. Connection description.
  featureEnablements: Optional. A list of feature enablement status.
  name: Output only. Immutable. The relative resource name of an other-cloud
    connection, which is unique across Google Cloud organizations. This
    field is used to uniquely identify other-cloud connection resource. It
    contains organization number and other_cloud_connection_id when creating
    other-cloud connection. This field is immutable once resource is
    created. And currently "aws" and "azure" are allowed as the
    other_cloud_connection_id. Format: organizations/{organization_number}/o
    therCloudConnections/{other_cloud_connection_id} E.g. -
    `organizations/123/otherCloudConnections/aws` -
    `organizations/123/otherCloudConnections/azure`
  serviceAgentId: Output only. Immutable. The service agent ID that will be
    used to connect to the provider.
  validationResults: Output only. The latest 10 validation results of the
    other-cloud connection. It is ordered by timestamp descendingly. When
    there is a new result generated by VerifyOtherCloudConnection API, the
    latest result will be inserted at the beginning of this field, and the
    last element will be removed when needed to keep its maximum size as 10.
c                   $    \ rS rSrSrSrSrSrSrg)2OtherCloudConnection.ConnectionTypeValueValuesEnumi4  zRequired. The other-cloud connection type.

Values:
  CONNECTION_TYPE_UNSPECIFIED: Connection type unspecified.
  COLLECT_AWS_ASSET: Collects asset config data from AWS.
  COLLECT_AZURE_ASSET: Collects asset config data from Azure.
r   r   r   r   N)	r   r   r   r   r   CONNECTION_TYPE_UNSPECIFIEDCOLLECT_AWS_ASSETCOLLECT_AZURE_ASSETr   r   r   r   ConnectionTypeValueValuesEnumr  4  s     #$r   r  rm  r   r  r   r   r   rh   r  ry   Tr   rz   r|   ValidationResultr~   r   N)r   r   r   r   r   r   r   r  r.   collectAwsAssetSettingcollectAzureAssetSettingr   connectionTyper   r8   r  featureEnablementsr   serviceAgentIdvalidationResultsr   r   r   r   rF  rF    s     D
inn 
 %112JAN&334NPQR&&'FJ.$$Q'*%%a(+ --.A1tT			q	!$((+.,,-?TRr   rF  c                       \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	\R                  " S5      r\R                  " SS5      r\R                  " S	5      rS
rg)r   iK  aE  Properties specific to this other-cloud (or alternative) provider.

Enums:
  DataSourceProviderValueValuesEnum: The data source provider of this asset.

Fields:
  awsDetails: For an asset fetched from AWS.
  connection: The full name of the OtherCloudConnection that is used to
    collect this resource Format:
    `//cloudasset.googleapis.com/organizations//OtherCloudConnections/`
  dataSourceProvider: The data source provider of this asset.
  name: The original name of the resource, such as AWS ARN. It must be able
    to uniquely identify that resource in the data source.
c                        \ rS rSrSrSrSrSrg)6OtherCloudProperties.DataSourceProviderValueValuesEnumi[  zThe data source provider of this asset.

Values:
  PROVIDER_UNSPECIFIED: The unspecified value for data source provider.
  AMAZON_WEB_SERVICES: The value for AWS.
r   r   r   N)r   r   r   r   r   r  r  r   r   r   r   r  r  [  s     r   r  r	   r   r   r   r   r   N)r   r   r   r   r   r   r   r  r.   
awsDetailsr   r  r   r  r   r   r   r   r   r   r   K  s`    )..  %%lA6*$$Q'* **+NPQR			q	!$r   r   c                   d    \ rS rSrSr\R                  " SS5      r\R                  " SS5      rSr	g)	r  ik  zOutput configuration for export assets destination.

Fields:
  bigqueryDestination: Destination on BigQuery. The output table stores the
    fields in asset Protobuf as columns in BigQuery.
  gcsDestination: Destination on Cloud Storage.
r   r   r  r   r   Nr5  r   r   r   r  r  k  s0     "../DaH))*:A>.r   r  c                   h    \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	Sr
g)r   ix  zSpecifications of BigQuery partitioned table as export destination.

Enums:
  PartitionKeyValueValuesEnum: The partition key for BigQuery partitioned
    table.

Fields:
  partitionKey: The partition key for BigQuery partitioned table.
c                   $    \ rS rSrSrSrSrSrSrg))PartitionSpec.PartitionKeyValueValuesEnumi  a  The partition key for BigQuery partitioned table.

Values:
  PARTITION_KEY_UNSPECIFIED: Unspecified partition key. If used, it means
    using non-partitioned table.
  READ_TIME: The time when the snapshot is taken. If specified as
    partition key, the result table(s) is partitioned by the additional
    timestamp column, readTime. If [read_time] in ExportAssetsRequest is
    specified, the readTime column's value will be the same as it.
    Otherwise, its value will be the current time that is used to take the
    snapshot.
  REQUEST_TIME: The time when the request is received and started to be
    processed. If specified as partition key, the result table(s) is
    partitioned by the requestTime column, an additional timestamp column
    representing when the request was received.
r   r   r   r   N)	r   r   r   r   r   r  	READ_TIMEr  r   r   r   r   r   r    s      !"ILr   r   r   r   N)r   r   r   r   r   r   r   r   r   r!  r   r   r   r   r   r   x  s,    INN * $$%BAF,r   r   c                   :    \ rS rSrSr\R                  " SSS9rSrg)r  i  zsIAM permissions

Fields:
  permissions: A list of permissions. A sample permission string:
    `compute.disk.get`.
r   Tr   r   N)	r   r   r   r   r   r   r   r&   r   r   r   r   r  r    s     %%a$7+r   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)rx   i  aw  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`, or principals, to a
single `role`. Principals 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`, or principals, with 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
    principal. The `bindings` in a `Policy` can refer to up to 1,500
    principals; up to 250 of these principals can be Google groups. Each
    occurrence of a principal counts towards these limits. For example, if
    the `bindings` grant 50 different roles to `user:alice@example.com`, and
    not to any other principal, then you can add another 1,450 principals to
    the `bindings` in the `Policy`.
  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).
r   r   Tr   r   r   r   r   r,   r   N)r   r   r   r   r   r   r.   auditConfigsbindingsr  r  r1   r2   r3   r  r   r   r   r   rx   rx     sa    EN ''q4H,##Iq4@(			a	 $""1i.?.?.E.EF'r   rx   c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)r  i  zThe IAM policy and its attached resource.

Fields:
  attachedResource: The full resource name the policy is directly attached
    to.
  policy: The IAM policy that's directly attached to the attached_resource.
r   rx   r   r   N)r   r   r   r   r   r   r   rj   r.   r  r   r   r   r   r  r    s,     **1-!!(A.&r   r  c                   <    \ rS rSrSr\R                  " S5      rSrg)r  i  zA Pub/Sub destination.

Fields:
  topic: The name of the Pub/Sub topic to publish to. Example:
    `projects/PROJECT_ID/topics/TOPIC_ID`.
r   r   N)	r   r   r   r   r   r   r   topicr   r   r   r   r  r    s     


"%r   r  c                   >    \ rS rSrSr\R                  " SS5      rSrg)QueryAssetsOutputConfigi  zOutput configuration query assets.

Fields:
  bigqueryDestination: BigQuery destination where the query results will be
    saved.
ra  r   r   N)	r   r   r   r   r   r   r.   r6  r   r   r   r   r  r    s     "../mopqr   r  c                   b   \ rS rSrSr\R                  " S5      r\R                  " SS5      r	\R                  " S\R                  R                  S9r\R                  " S5      r\R                  " S	5      r\R                  " S
S5      r\R                  " S5      r\R                  " S5      rSrg)rV  i  a  QueryAssets request.

Fields:
  jobReference: Optional. Reference to the query job, which is from the
    `QueryAssetsResponse` of previous `QueryAssets` call.
  outputConfig: Optional. Destination where the query results will be saved.
    When this field is specified, the query results won't be saved in the
    [QueryAssetsResponse.query_result]. Instead
    [QueryAssetsResponse.output_config] will be set. Meanwhile,
    [QueryAssetsResponse.job_reference] will be set and can be used to check
    the status of the query job when passed to a following [QueryAssets] API
    call.
  pageSize: Optional. The maximum number of rows to return in the results.
    Responses are limited to 10 MB and 1000 rows. By default, the maximum
    row count is 1000. When the byte or row count limit is reached, the rest
    of the query results will be paginated. The field will be ignored when
    [output_config] is specified.
  pageToken: Optional. A page token received from previous `QueryAssets`.
    The field will be ignored when [output_config] is specified.
  readTime: Optional. Queries cloud assets as they appeared at the specified
    point in time.
  readTimeWindow: Optional. [start_time] is required. [start_time] must be
    less than [end_time] Defaults [end_time] to now if [start_time] is set
    and [end_time] isn't. Maximum permitted time range is 7 days.
  statement: Optional. A SQL statement that's compatible with [BigQuery
    SQL](https://cloud.google.com/bigquery/docs/introduction-sql).
  timeout: Optional. Specifies the maximum amount of time that the client is
    willing to wait for the query to complete. By default, this limit is 5
    min for the first query, and 1 minute for the following queries. If the
    query is complete, the `done` field in the `QueryAssetsResponse` is
    true, otherwise false. Like BigQuery [jobs.query API](https://cloud.goog
    le.com/bigquery/docs/reference/rest/v2/jobs/query#queryrequest) The call
    is not guaranteed to wait for the specified timeout; it typically
    returns after around 200 seconds (200,000 milliseconds), even if the
    query is not complete. The field will be ignored when [output_config] is
    specified.
r   r  r   r   r,   r   rh   
TimeWindowry   rz   r|   r   N)r   r   r   r   r   r   r   jobReferencer.   r?   r1   r2   r3   r  r  r  readTimeWindow	statementtimeoutr   r   r   r   rV  rV    s    $L &&q),''(A1E,##Ay/@/@/F/FG(##A&)""1%()),:.##A&)!!!$'r   rV  c                       \ rS rSrSr\R                  " S5      r\R                  " SS5      r	\R                  " S5      r\R                  " SS5      r\R                  " S	S
5      rSrg)QueryAssetsResponseiH  a  QueryAssets response.

Fields:
  done: The query response, which can be either an `error` or a valid
    `response`. If `done` == `false` and the query result is being saved in
    an output, the output_config field will be set. If `done` == `true`,
    exactly one of `error`, `query_result` or `output_config` will be set.
    [done] is unset unless the [QueryAssetsResponse] contains a
    [QueryAssetsResponse.job_reference].
  error: Error status.
  jobReference: Reference to a query job.
  outputConfig: Output configuration, which indicates that instead of being
    returned in an API response on the fly, the query result will be saved
    in a specific output.
  queryResult: Result of the query.
r   r  r   r   r  r   QueryResultrh   r   N)r   r   r   r   r   r   rI   r  r.   r  r   r	  r?   queryResultr   r   r   r   r  r  H  s`    " 
			"$

 
 1
-%&&q),''(A1E,&&}a8+r   r  c                   >    \ rS rSrSr\R                  " SS5      rSrg)QueryContentia  zThe query content.

Fields:
  iamPolicyAnalysisQuery: An IAM Policy Analysis query, which could be used
    in the AssetService.AnalyzeIamPolicy RPC or the
    AssetService.AnalyzeIamPolicyLongrunning RPC.
r<   r   r   N)	r   r   r   r   r   r   r.   iamPolicyAnalysisQueryr   r   r   r   r  r  a  s     %112JANr   r  c                       \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " S5      r\R                  " SSSS	9r\R                  " S
S5      r\R                  " S5      rSrg)r  im  a  Execution results of the query. The result is formatted as rows
represented by BigQuery compatible [schema]. When pagination is necessary,
it will contains the page token to retrieve the results of following pages.

Messages:
  RowsValueListEntry: A RowsValueListEntry object.

Fields:
  nextPageToken: Token to retrieve the next page of the results.
  rows: Each row hold a query result in the format of `Struct`.
  schema: Describes the format of the [rows].
  totalRows: Total rows of the whole query results.
rn  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
QueryResult.RowsValueListEntryi|  zA RowsValueListEntry object.

Messages:
  AdditionalProperty: An additional property for a RowsValueListEntry
    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)1QueryResult.RowsValueListEntry.AdditionalPropertyi  zAn additional property for a RowsValueListEntry object.

Fields:
  key: Name of the additional property.
  value: A extra_types.JsonValue attribute.
r   r  r   r   Nr  r   r   r   ru  r    r  r   ru  r   Tr   r   Nrv  r   r   r   RowsValueListEntryr  |  r  r   r  r   r   Tr   TableSchemar   r   r   N)r   r   r   r   r   r   r{  r   rw  r  r   rX   r.   rowsschemar1   	totalRowsr   r   r   r   r  r  m  s     !!"89Z9,, Z :Z0 ''*-			 4a$	G$!!-3&$$Q')r   r  c                       \ rS rSrSr\R                  " SSS9r\R                  " S5      r\R                  " S5      r	\R                  " S5      r
S	rg
)r   i  a  An asset identifier in Google Cloud which contains its name, type and
ancestors. 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.
IAM policy). See [Supported asset types](https://cloud.google.com/asset-
inventory/docs/supported-asset-types) for more information.

Fields:
  ancestors: The ancestors 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. Example: `["projects/123456789",
    "folders/5432", "organizations/1234"]`
  asset: The full name of the asset. Example: `//compute.googleapis.com/proj
    ects/my_project_123/zones/zone1/instances/instance1` See [Resource names
    ](https://cloud.google.com/apis/design/resource_names#full_resource_name
    ) for more information.
  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.
  relationshipType: The unique identifier of the relationship type. Example:
    `INSTANCE_TO_INSTANCEGROUP`
r   Tr   r   r   r   r   N)r   r   r   r   r   r   r   r   rr  r   relationshipTyper   r   r   r   r   r     sL    4 ##A5)



"%##A&)**1-r   r   c                   b    \ rS rSrSr\R                  " SSSS9r\R                  " SS5      rS	r	g
)r   i  aB  DEPRECATED. This message only presents for the purpose of backward-
compatibility. The server will never populate this message in responses. The
detailed related assets with the `relationship_type`.

Fields:
  assets: The peer resources of the relationship.
  relationshipAttributes: The detailed relationship attributes.
r   r   Tr   RelationshipAttributesr   r   Nru  r   r   r   r   r     s1     !!.!dC&$112JANr   r   c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)RelatedResourcei  a  The detailed related resource.

Fields:
  assetType: The type of the asset. Example:
    `compute.googleapis.com/Instance`
  fullResourceName: The full resource name of the related resource. Example:
    `//compute.googleapis.com/projects/my_proj_123/zones/instance/instance12
    3`
r   r   r   N)
r   r   r   r   r   r   r   r   r  r   r   r   r   r#  r#    s*     ##A&)**1-r   r#  c                   <    \ rS rSrSr\R                  " SSSS9rSrg)	RelatedResourcesi  zThe related resources of the primary resource.

Fields:
  relatedResources: The detailed related resources of the primary resource.
r#  r   Tr   r   N)	r   r   r   r   r   r   r.   relatedResourcesr   r   r   r   r%  r%    s     ++,=q4Pr   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`  DEPRECATED. This message only presents for the purpose of backward-
compatibility. The server will never populate this message in responses. The
relationship attributes which include `type`, `source_resource_type`,
`target_resource_type` and `action`.

Fields:
  action: The detail of the relationship, e.g. `contains`, `attaches`
  sourceResourceType: The source asset type. Example:
    `compute.googleapis.com/Instance`
  targetResourceType: The target asset type. Example:
    `compute.googleapis.com/Disk`
  type: The unique identifier of the relationship type. Example:
    `INSTANCE_TO_INSTANCEGROUP`
r   r   r   r   r   Nrx  r   r   r   r!  r!    sK       #& ,,Q/ ,,Q/			q	!$r   r!  c                   j   \ rS rSrS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	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.

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.
  location: The location of the resource in Google Cloud, such as its zone
    and region. For more information, see
    https://cloud.google.com/about/locations/.
  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 [IAM policy
    hierarchy](https://cloud.google.com/iam/docs/overview#policy_hierarchy).
    Example: `//cloudresourcemanager.googleapis.com/projects/my_project_123`
  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`
rn  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.DataValuei  r  c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)%Resource.DataValue.AdditionalPropertyi'  r  r   r  r   r   Nr  r   r   r   ru  r,  '  r  r   ru  r   Tr   r   Nrv  r   r   r   r  r*    r  r   r  r   r   r   r   rh   ry   rz   r   Nr  r   r   r   r   r     s    B !!"89Z)## Z :Z0 
		Q	/$"..q1''*-""1%(  #&%%a(+!!!$'r   r   c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)r   i=  a8  Additional information for resource group from Azure

Fields:
  resourceGroupName: The Azure Resource Group
    [name](https://learn.microsoft.com/en-us/rest/api/resources/resource-
    groups/list?view=rest-resources-2021-04-01#resourcegroupproperties)
    E.g.: myResourceGroup
  resourceGroupResourceId: The Azure Resource Group ID
    (https://learn.microsoft.com/en-us/rest/api/resources/resource-
    groups/list?view=rest-resources-2021-04-01#resourcegroupproperties)
    E.g.: /subscriptions/1a11aad8-de27-1234-85e9-
    0f675821f15c/resourceGroups/group-name
r   r   r   N)
r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   =  s+      ++A.%11!4r   r   c                   :    \ rS rSrSr\R                  " SSS9rSrg)r   iP  zUThe resource owners information.

Fields:
  resourceOwners: List of resource owners.
r   Tr   r   N)	r   r   r   r   r   r   r   r   r   r   r   r   r   r   P  s     ((T:.r   r   c                   T   \ 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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SSS9r\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                  " SSSS9r\R                  " SSSS9r\R                  " SSS9r\R                  " S5      r\R                  " SSS9r\R                  " S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!\R                  " S	S$5      r"\R                  " SS%5      r#\R                  " S&5      r$\R                  " S'SS9r%\R                  " S(SS9r&\R                  " S)SS9r'\R                  " S*S+SS9r(\R                  " S,5      r)\R                  " S-S.SS9r*S/r+g0)1ResourceSearchResultiZ  a=  A result of Resource Search, containing information of a cloud resource.

Messages:
  AdditionalAttributesValue: The additional searchable attributes of this
    resource. The attributes may vary from one resource type to another.
    Examples: `projectId` for Project, `dnsName` for DNS ManagedZone. This
    field contains a subset of the resource metadata fields that are
    returned by the List or Get APIs provided by the corresponding Google
    Cloud service (e.g., Compute Engine). see [API references and supported
    searchable attributes](https://cloud.google.com/asset-
    inventory/docs/supported-asset-types) to see which fields are included.
    You can search values of these fields through free text search. However,
    you should not consume the field programically as the field names and
    values may change as the Google Cloud service updates to a new
    incompatible API version. To search against the `additional_attributes`:
    * Use a free text query to match the attributes values. Example: to
    search `additional_attributes = { dnsName: "foobar" }`, you can issue a
    query `foobar`.
  LabelsValue: User labels associated with this resource. See [Labelling and
    grouping Google Cloud
    resources](https://cloud.google.com/blog/products/gcp/labelling-and-
    grouping-your-google-cloud-platform-resources) for more information.
    This field is available only when the resource's Protobuf contains it.
    To search against the `labels`: * Use a field query: - query on any
    label's key or value. Example: `labels:prod` - query by a given label.
    Example: `labels.env:prod` - query by a given label's existence.
    Example: `labels.env:*` * Use a free text query. Example: `prod`
  RelationshipsValue: A map of related resources of this resource, keyed by
    the relationship type. A relationship type is in the format of
    {SourceType}_{ACTION}_{DestType}. Example: `DISK_TO_INSTANCE`,
    `DISK_TO_NETWORK`, `INSTANCE_TO_INSTANCEGROUP`. See [supported
    relationship types](https://cloud.google.com/asset-
    inventory/docs/supported-asset-types#supported_relationship_types).
  SccSecurityMarksValue: The actual content of Security Command Center
    security marks associated with the asset. To search against SCC
    SecurityMarks field: * Use a field query: - query by a given key value
    pair. Example: `sccSecurityMarks.foo=bar` - query by a given key's
    existence. Example: `sccSecurityMarks.foo:*`

Fields:
  additionalAttributes: The additional searchable attributes of this
    resource. The attributes may vary from one resource type to another.
    Examples: `projectId` for Project, `dnsName` for DNS ManagedZone. This
    field contains a subset of the resource metadata fields that are
    returned by the List or Get APIs provided by the corresponding Google
    Cloud service (e.g., Compute Engine). see [API references and supported
    searchable attributes](https://cloud.google.com/asset-
    inventory/docs/supported-asset-types) to see which fields are included.
    You can search values of these fields through free text search. However,
    you should not consume the field programically as the field names and
    values may change as the Google Cloud service updates to a new
    incompatible API version. To search against the `additional_attributes`:
    * Use a free text query to match the attributes values. Example: to
    search `additional_attributes = { dnsName: "foobar" }`, you can issue a
    query `foobar`.
  assetType: The type of this resource. Example:
    `compute.googleapis.com/Disk`. To search against the `asset_type`: *
    Specify the `asset_type` field in your search request.
  attachedResources: Attached resources of this resource. For example, an
    OSConfig Inventory is an attached resource of a Compute Instance. This
    field is repeated because a resource could have multiple attached
    resources. This `attached_resources` field is not searchable. Some
    attributes of the attached resources are exposed in
    `additional_attributes` field, so as to allow users to search on them.
  createTime: The create timestamp of this resource, at which the resource
    was created. The granularity is in seconds. Timestamp.nanos will always
    be 0. This field is available only when the resource's Protobuf contains
    it. To search against `create_time`: * Use a field query. - value in
    seconds since unix epoch. Example: `createTime > 1609459200` - value in
    date string. Example: `createTime > 2021-01-01` - value in date-time
    string (must be quoted). Example: `createTime > "2021-01-01T00:00:00"`
  description: One or more paragraphs of text description of this resource.
    Maximum length could be up to 1M bytes. This field is available only
    when the resource's Protobuf contains it. To search against the
    `description`: * Use a field query. Example: `description:"important
    instance"` * Use a free text query. Example: `"important instance"`
  displayName: The display name of this resource. This field is available
    only when the resource's Protobuf contains it. To search against the
    `display_name`: * Use a field query. Example: `displayName:"My
    Instance"` * Use a free text query. Example: `"My Instance"`
  effectiveTags: The effective tags on this resource. All of the tags that
    are both attached to and inherited by a resource are collectively called
    the effective tags. For more information, see [tag
    inheritance](https://cloud.google.com/resource-manager/docs/tags/tags-
    overview#inheritance). To search against the `effective_tags`: * Use a
    field query. Example: - `effectiveTagKeys:"123456789/env*"` -
    `effectiveTagKeys="123456789/env"` - `effectiveTagKeys:"env"` -
    `effectiveTagKeyIds="tagKeys/123"` - `effectiveTagValues:"env"` -
    `effectiveTagValues:"env/prod"` -
    `effectiveTagValues:"123456789/env/prod*"` -
    `effectiveTagValues="123456789/env/prod"` -
    `effectiveTagValueIds="tagValues/456"`
  enrichments: Enrichments of the asset. Currently supported enrichment
    types with SearchAllResources API: * RESOURCE_OWNERS The corresponding
    read masks in order to get the enrichment: * enrichments.resource_owners
    The corresponding required permissions: *
    cloudasset.assets.searchEnrichmentResourceOwners Example query to get
    resource owner enrichment: ``` scope: "projects/my-project" query:
    "name: my-project" assetTypes:
    "cloudresourcemanager.googleapis.com/Project" readMask: { paths:
    "asset_type" paths: "name" paths: "enrichments.resource_owners" } ```
  folders: The folder(s) that this resource belongs to, in the form of
    folders/{FOLDER_NUMBER}. This field is available when the resource
    belongs to one or more folders. To search against `folders`: * Use a
    field query. Example: `folders:(123 OR 456)` * Use a free text query.
    Example: `123` * Specify the `scope` field as this folder in your search
    request.
  kmsKey: The Cloud KMS [CryptoKey](https://cloud.google.com/kms/docs/refere
    nce/rest/v1/projects.locations.keyRings.cryptoKeys) name or [CryptoKeyVe
    rsion](https://cloud.google.com/kms/docs/reference/rest/v1/projects.loca
    tions.keyRings.cryptoKeys.cryptoKeyVersions) name. This field only
    presents for the purpose of backward compatibility. Use the `kms_keys`
    field to retrieve Cloud KMS key information. This field is available
    only when the resource's Protobuf contains it and will only be populated
    for [these resource types](https://cloud.google.com/asset-
    inventory/docs/legacy-field-
    names#resource_types_with_the_to_be_deprecated_kmskey_field) for
    backward compatible purposes. To search against the `kms_key`: * Use a
    field query. Example: `kmsKey:key` * Use a free text query. Example:
    `key`
  kmsKeys: The Cloud KMS [CryptoKey](https://cloud.google.com/kms/docs/refer
    ence/rest/v1/projects.locations.keyRings.cryptoKeys) names or [CryptoKey
    Version](https://cloud.google.com/kms/docs/reference/rest/v1/projects.lo
    cations.keyRings.cryptoKeys.cryptoKeyVersions) names. This field is
    available only when the resource's Protobuf contains it. To search
    against the `kms_keys`: * Use a field query. Example: `kmsKeys:key` *
    Use a free text query. Example: `key`
  labels: User labels associated with this resource. See [Labelling and
    grouping Google Cloud
    resources](https://cloud.google.com/blog/products/gcp/labelling-and-
    grouping-your-google-cloud-platform-resources) for more information.
    This field is available only when the resource's Protobuf contains it.
    To search against the `labels`: * Use a field query: - query on any
    label's key or value. Example: `labels:prod` - query by a given label.
    Example: `labels.env:prod` - query by a given label's existence.
    Example: `labels.env:*` * Use a free text query. Example: `prod`
  location: Location can be `global`, regional like `us-east1`, or zonal
    like `us-west1-b`. This field is available only when the resource's
    Protobuf contains it. To search against the `location`: * Use a field
    query. Example: `location:us-west*` * Use a free text query. Example:
    `us-west*`
  name: The full resource name of this resource. Example: `//compute.googlea
    pis.com/projects/my_project_123/zones/zone1/instances/instance1`. See
    [Cloud Asset Inventory Resource Name
    Format](https://cloud.google.com/asset-inventory/docs/resource-name-
    format) for more information. To search against the `name`: * Use a
    field query. Example: `name:instance1` * Use a free text query. Example:
    `instance1`
  networkTags: Network tags associated with this resource. Like labels,
    network tags are a type of annotations used to group Google Cloud
    resources. See [Labelling Google Cloud
    resources](https://cloud.google.com/blog/products/gcp/labelling-and-
    grouping-your-google-cloud-platform-resources) for more information.
    This field is available only when the resource's Protobuf contains it.
    To search against the `network_tags`: * Use a field query. Example:
    `networkTags:internal` * Use a free text query. Example: `internal`
  organization: The organization that this resource belongs to, in the form
    of organizations/{ORGANIZATION_NUMBER}. This field is available when the
    resource belongs to an organization. To search against `organization`: *
    Use a field query. Example: `organization:123` * Use a free text query.
    Example: `123` * Specify the `scope` field as this organization in your
    search request.
  parentAssetType: The type of this resource's immediate parent, if there is
    one. To search against the `parent_asset_type`: * Use a field query.
    Example: `parentAssetType:"cloudresourcemanager.googleapis.com/Project"`
    * Use a free text query. Example:
    `cloudresourcemanager.googleapis.com/Project`
  parentFullResourceName: The full resource name of this resource's parent,
    if it has one. To search against the `parent_full_resource_name`: * Use
    a field query. Example: `parentFullResourceName:"project-name"` * Use a
    free text query. Example: `project-name`
  project: The project that this resource belongs to, in the form of
    projects/{PROJECT_NUMBER}. This field is available when the resource
    belongs to a project. To search against `project`: * Use a field query.
    Example: `project:12345` * Use a free text query. Example: `12345` *
    Specify the `scope` field as this project in your search request.
  relationships: A map of related resources of this resource, keyed by the
    relationship type. A relationship type is in the format of
    {SourceType}_{ACTION}_{DestType}. Example: `DISK_TO_INSTANCE`,
    `DISK_TO_NETWORK`, `INSTANCE_TO_INSTANCEGROUP`. See [supported
    relationship types](https://cloud.google.com/asset-
    inventory/docs/supported-asset-types#supported_relationship_types).
  sccSecurityMarks: The actual content of Security Command Center security
    marks associated with the asset. To search against SCC SecurityMarks
    field: * Use a field query: - query by a given key value pair. Example:
    `sccSecurityMarks.foo=bar` - query by a given key's existence. Example:
    `sccSecurityMarks.foo:*`
  state: The state of this resource. Different resources types have
    different state definitions that are mapped from various fields of
    different resource types. This field is available only when the
    resource's Protobuf contains it. Example: If the resource is an instance
    provided by Compute Engine, its state will include PROVISIONING,
    STAGING, RUNNING, STOPPING, SUSPENDING, SUSPENDED, REPAIRING, and
    TERMINATED. See `status` definition in [API Reference](https://cloud.goo
    gle.com/compute/docs/reference/rest/v1/instances). If the resource is a
    project provided by Resource Manager, its state will include
    LIFECYCLE_STATE_UNSPECIFIED, ACTIVE, DELETE_REQUESTED and
    DELETE_IN_PROGRESS. See `lifecycleState` definition in [API
    Reference](https://cloud.google.com/resource-
    manager/reference/rest/v1/projects). To search against the `state`: *
    Use a field query. Example: `state:RUNNING` * Use a free text query.
    Example: `RUNNING`
  tagKeys: This field is only present for the purpose of backward
    compatibility. Use the `tags` field instead. TagKey namespaced names, in
    the format of {ORG_ID}/{TAG_KEY_SHORT_NAME}. To search against the
    `tagKeys`: * Use a field query. Example: - `tagKeys:"123456789/env*"` -
    `tagKeys="123456789/env"` - `tagKeys:"env"` * Use a free text query.
    Example: - `env`
  tagValueIds: This field is only present for the purpose of backward
    compatibility. Use the `tags` field instead. TagValue IDs, in the format
    of tagValues/{TAG_VALUE_ID}. To search against the `tagValueIds`: * Use
    a field query. Example: - `tagValueIds="tagValues/456"` * Use a free
    text query. Example: - `456`
  tagValues: This field is only present for the purpose of backward
    compatibility. Use the `tags` field instead. TagValue namespaced names,
    in the format of {ORG_ID}/{TAG_KEY_SHORT_NAME}/{TAG_VALUE_SHORT_NAME}.
    To search against the `tagValues`: * Use a field query. Example: -
    `tagValues:"env"` - `tagValues:"env/prod"` -
    `tagValues:"123456789/env/prod*"` - `tagValues="123456789/env/prod"` *
    Use a free text query. Example: - `prod`
  tags: The tags directly attached to this resource. To search against the
    `tags`: * Use a field query. Example: - `tagKeys:"123456789/env*"` -
    `tagKeys="123456789/env"` - `tagKeys:"env"` - `tagKeyIds="tagKeys/123"`
    - `tagValues:"env"` - `tagValues:"env/prod"` -
    `tagValues:"123456789/env/prod*"` - `tagValues="123456789/env/prod"` -
    `tagValueIds="tagValues/456"` * Use a free text query. Example: -
    `env/prod`
  updateTime: The last update timestamp of this resource, at which the
    resource was last modified or deleted. The granularity is in seconds.
    Timestamp.nanos will always be 0. This field is available only when the
    resource's Protobuf contains it. To search against `update_time`: * Use
    a field query. - value in seconds since unix epoch. Example: `updateTime
    < 1609459200` - value in date string. Example: `updateTime < 2021-01-01`
    - value in date-time string (must be quoted). Example: `updateTime <
    "2021-01-01T00:00:00"`
  versionedResources: Versioned resource representations of this resource.
    This is repeated because there could be multiple versions of resource
    representations during version migration. This `versioned_resources`
    field is not searchable. Some attributes of the resource representations
    are exposed in `additional_attributes` field, so as to allow users to
    search on them.
rn  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
.ResourceSearchResult.AdditionalAttributesValueiN  aY  The additional searchable attributes of this resource. The attributes
may vary from one resource type to another. Examples: `projectId` for
Project, `dnsName` for DNS ManagedZone. This field contains a subset of
the resource metadata fields that are returned by the List or Get APIs
provided by the corresponding Google Cloud service (e.g., Compute Engine).
see [API references and supported searchable
attributes](https://cloud.google.com/asset-inventory/docs/supported-asset-
types) to see which fields are included. You can search values of these
fields through free text search. However, you should not consume the field
programically as the field names and values may change as the Google Cloud
service updates to a new incompatible API version. To search against the
`additional_attributes`: * Use a free text query to match the attributes
values. Example: to search `additional_attributes = { dnsName: "foobar"
}`, you can issue a query `foobar`.

Messages:
  AdditionalProperty: An additional property for a
    AdditionalAttributesValue 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)AResourceSearchResult.AdditionalAttributesValue.AdditionalPropertyig  zAn additional property for a AdditionalAttributesValue object.

Fields:
  key: Name of the additional property.
  value: A extra_types.JsonValue attribute.
r   r  r   r   Nr  r   r   r   ru  r4  g  r  r   ru  r   Tr   r   Nrv  r   r   r   AdditionalAttributesValuer2  N  s4    .	AY.. 	A %112FTXYr   r5  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
 ResourceSearchResult.LabelsValueit  a  User labels associated with this resource. See [Labelling and grouping
Google Cloud
resources](https://cloud.google.com/blog/products/gcp/labelling-and-
grouping-your-google-cloud-platform-resources) for more information. This
field is available only when the resource's Protobuf contains it. To
search against the `labels`: * Use a field query: - query on any label's
key or value. Example: `labels:prod` - query by a given label. Example:
`labels.env:prod` - query by a given label's existence. Example:
`labels.env:*` * Use a free text query. Example: `prod`

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

Fields:
  additionalProperties: Additional properties of type LabelsValue
c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)3ResourceSearchResult.LabelsValue.AdditionalPropertyi  An additional property for a LabelsValue object.

Fields:
  key: Name of the additional property.
  value: A string attribute.
r   r   r   N
r   r   r   r   r   r   r   rs  rt  r   r   r   r   ru  r9    )    
 !!!$c##A&er   ru  r   Tr   r   Nrv  r   r   r   LabelsValuer7  t  s2    "	'Y.. 	' %112FTXYr   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	)
'ResourceSearchResult.RelationshipsValuei  a  A map of related resources of this resource, keyed by the relationship
type. A relationship type is in the format of
{SourceType}_{ACTION}_{DestType}. Example: `DISK_TO_INSTANCE`,
`DISK_TO_NETWORK`, `INSTANCE_TO_INSTANCEGROUP`. See [supported
relationship types](https://cloud.google.com/asset-
inventory/docs/supported-asset-types#supported_relationship_types).

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

Fields:
  additionalProperties: Additional properties of type RelationshipsValue
c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g):ResourceSearchResult.RelationshipsValue.AdditionalPropertyi  zAn additional property for a RelationshipsValue object.

Fields:
  key: Name of the additional property.
  value: A RelatedResources attribute.
r   r%  r   r   Nr  r   r   r   ru  rA    s,    
 !!!$c$$%7;er   ru  r   Tr   r   Nrv  r   r   r   RelationshipsValuer?    s2    	<Y.. 	< %112FTXYr   rB  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
*ResourceSearchResult.SccSecurityMarksValuei  a  The actual content of Security Command Center security marks
associated with the asset. To search against SCC SecurityMarks field: *
Use a field query: - query by a given key value pair. Example:
`sccSecurityMarks.foo=bar` - query by a given key's existence. Example:
`sccSecurityMarks.foo:*`

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

Fields:
  additionalProperties: Additional properties of type
    SccSecurityMarksValue
c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)=ResourceSearchResult.SccSecurityMarksValue.AdditionalPropertyi  zAn additional property for a SccSecurityMarksValue object.

Fields:
  key: Name of the additional property.
  value: A string attribute.
r   r   r   Nr;  r   r   r   ru  rF    r<  r   ru  r   Tr   r   Nrv  r   r   r   SccSecurityMarksValuerD    s2    	'Y.. 	' %112FTXYr   rG  r   r   r   r   Tr   r   rh   ry   r  rz   r   r|   r~   r   r   r   r   r   r   rI     r
                        r        r      r   N),r   r   r   r   r   r   r{  r   rw  r5  r=  rB  rG  r.   additionalAttributesr   r   attachedResourcesr8   r  r0  r  enrichmentsr  kmsKeykmsKeyslabelsr  r   networkTagsr    parentAssetTypeparentFullResourceNamer  relationshipssccSecurityMarksr  tagKeystagValueIds	tagValuestagsr   r   r   r   r   r   r0  r0  Z  s   qf !!"89#Z)"3"3 #Z :#ZJ !!"89ZI%% Z :Z> !!"89Z9,, Z :Z: !!"89Zi// Z :Z: #//0KQO##A&),,-?TR$$Q'*%%a(+%%a(+(()>DQ-&&'8!dK+!!!d3'  $&!!"t4'!!-4&""2&(			r	"$%%b48+&&r*,))"-/$004!!"%'(()=rB-++,CRH



#%!!"t4'%%b48+##B6)			rD	9$$$R(* --.A2PTUr   r0  c                   <    \ rS rSrSr\R                  " S5      rSrg)r;  i  a  Specifies the resource to analyze for access policies, which may be set
directly on the resource, or on ancestors such as organizations, folders or
projects.

Fields:
  fullResourceName: Required. The [full resource name]
    (https://cloud.google.com/asset-inventory/docs/resource-name-format) of
    a resource of [supported resource types](https://cloud.google.com/asset-
    inventory/docs/supported-asset-types#analyzable_asset_types).
r   r   NrQ  r   r   r   r;  r;    s    	 **1-r   r;  c                      \ rS rSrS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
5      r\R                  " SS5      r\R                  " S5      r\R                  " S5      r\R                  " S5      rSrg)rZ  i  a  A saved query which can be shared with others or used later.

Messages:
  LabelsValue: Labels applied on the resource. This value should not contain
    more than 10 entries. The key and value of each entry must be non-empty
    and fewer than 64 characters.

Fields:
  content: The query content.
  createTime: Output only. The create time of this saved query.
  creator: Output only. The account's email address who has created this
    saved query.
  description: The description of this saved query. This value should be
    fewer than 255 characters.
  labels: Labels applied on the resource. This value should not contain more
    than 10 entries. The key and value of each entry must be non-empty and
    fewer than 64 characters.
  lastUpdateTime: Output only. The last update time of this saved query.
  lastUpdater: Output only. The account's email address who has updated this
    saved query most recently.
  name: The resource name of the saved query. The format must be: *
    projects/project_number/savedQueries/saved_query_id *
    folders/folder_number/savedQueries/saved_query_id *
    organizations/organization_number/savedQueries/saved_query_id
rn  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
SavedQuery.LabelsValuei  aA  Labels applied on the resource. This value should not contain more
than 10 entries. The key and value of each entry must be non-empty and
fewer than 64 characters.

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

Fields:
  additionalProperties: Additional properties of type LabelsValue
c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g))SavedQuery.LabelsValue.AdditionalPropertyi%  r:  r   r   r   Nr;  r   r   r   ru  rg  %  r<  r   ru  r   Tr   r   Nrv  r   r   r   r=  re    s2    		'Y.. 	' %112FTXYr   r=  r  r   r   r   r   rh   ry   rz   r|   r   N)r   r   r   r   r   r   r{  r   rw  r=  r.   r  r   r8   creatorr  rX  lastUpdateTimelastUpdaterr   r   r   r   r   rZ  rZ    s    4 !!"89ZI%% Z :Z2 "">15'$$Q'*!!!$'%%a(+!!-3&((+.%%a(+			q	!$r   rZ  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      r	Sr
g)ry  i<  zA ScanSensitiveDataSetting object.

Fields:
  roleNameToScanSensitiveData: A string attribute.
  scanSensitiveDataEnabled: A boolean attribute.
r   r   r   N)r   r   r   r   r   r   r   roleNameToScanSensitiveDatarI   scanSensitiveDataEnabledr   r   r   r   ry  ry  <  s+     !* 5 5a 8&33A6r   ry  c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
SearchAllIamPoliciesResponseiH  a  Search all IAM policies response.

Fields:
  nextPageToken: Set if there are more results than those appearing in this
    response; to get the next set of results, call this method again, using
    this value as the `page_token`.
  results: A list of IAM policies that match the search query. Related
    information such as the associated resource is returned along with the
    policy.
r   r_  r   Tr   r   Nr   r   r   r   r   r   r   rX   r.   resultsr   r   r   r   ro  ro  H  s.    	 ''*-""#:AM'r   ro  c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
SearchAllResourcesResponseiX  a  Search all resources response.

Fields:
  nextPageToken: If there are more results than those appearing in this
    response, then `next_page_token` is included. To get the next set of
    results, call this method again using the value of `next_page_token` as
    `page_token`.
  results: A list of Resources that match the search query. It contains the
    resource standard metadata information.
r   r0  r   Tr   r   Nrp  r   r   r   rs  rs  X  s.    	 ''*-""#91tL'r   rs  c                   <    \ rS rSrSr\R                  " S5      rSrg)r  ih  a  Scan sensitive data setting for Azure.

Fields:
  isEnabled: Optional. Whether we enable scanning sensitive data or not.
    Setting this to true means that this connection is enabled for SDP
    (Sensitive Data Protection) to scan sensitive data in customers' Azure
    environments, which requires extra scan sensitive data related
    permissions otherwise scanning sensitive data will fail.
r   r   N)	r   r   r   r   r   r   rI   	isEnabledr   r   r   r   r  r  h  s     $$Q')r   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      r	Sr
g)rz  iv  a  Sensitive Data Protection discovery setting.

Fields:
  isEnabled: Optional. Whether we enable Sensitive Data Protection discovery
    or not. Setting this to true means that this connection is enabled for
    SDP (Sensitive Data Protection) to scan sensitive data in customers' AWS
    accounts, which requires extra scan sensitive data related permissions
    otherwise scanning sensitive data will fail.
  roleName: Optional. Sensitive Data Protection role name for profiling AWS
    data. This role is used to profile data in AWS resources. This role is
    only required and used when
    sensitive_data_protection_discovery_setting.is_enabled is set to true.
r   r   r   N)r   r   r   r   r   r   rI   ru  r   roleNamer   r   r   r   rz  rz  v  s)     $$Q')""1%(r   rz  c                   n   \ rS rSrSr\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r	\R                  " SS5      r
\R                  " S	S
5      r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      rSrg)r  i  a  Software package information of the operating system.

Fields:
  aptPackage: Details of an APT package. For details about the apt package
    manager, see https://wiki.debian.org/Apt.
  cosPackage: Details of a COS package.
  googetPackage: Details of a Googet package. For details about the googet
    package manager, see https://github.com/google/googet.
  qfePackage: Details of a Windows Quick Fix engineering package. See
    https://docs.microsoft.com/en-
    us/windows/win32/cimwin32prov/win32-quickfixengineering for info in
    Windows Quick Fix Engineering.
  windowsApplication: Details of Windows Application.
  wuaPackage: Details of a Windows Update package. See
    https://docs.microsoft.com/en-us/windows/win32/api/_wua/ for information
    about Windows Update.
  yumPackage: Yum package info. For details about the yum package manager,
    see https://access.redhat.com/documentation/en-
    us/red_hat_enterprise_linux/6/html/deployment_guide/ch-yum.
  zypperPackage: Details of a Zypper package. For details about the Zypper
    package manager, see https://en.opensuse.org/SDB:Zypper_manual.
  zypperPatch: Details of a Zypper patch. For details about the Zypper
    package manager, see https://en.opensuse.org/SDB:Zypper_manual.
VersionedPackager   r   r   !WindowsQuickFixEngineeringPackager   WindowsApplicationrh   WindowsUpdatePackagery   rz   r|   ZypperPatchr~   r   N)r   r   r   r   r   r   r.   
aptPackage
cosPackagegoogetPackage
qfePackagewindowsApplication
wuaPackage
yumPackagezypperPackagezypperPatchr   r   r   r   r  r    s    2 %%&8!<*%%&8!<*(();Q?-%%&I1M* --.BAF%%&<a@*%%&8!<*(();Q?-&&}a8+r   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.AltValueValuesEnumi  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protor   r   r   r   AltValueValuesEnumr    s     DEEr   r  c                        \ rS rSrSrSrSrSrg)-StandardQueryParameters.FXgafvValueValuesEnumi  zFV1 error format.

Values:
  _1: v1 error format
  _2: v2 error format
r   r   r   N)r   r   r   r   r   _1_2r   r   r   r   FXgafvValueValuesEnumr    s     
B	
Br   r  r   r   r   r  )defaultr   rh   ry   rz   r|   Tr~   r   r   r   r   N)r   r   r   r   r   r   r   r  r  r   f__xgafvr   access_tokenaltcallbackfieldsrs  oauth_tokenrI   prettyPrint	quotaUsertrace
uploadTypeupload_protocolr   r   r   r   r  r    s    4
9>> 
inn    !8!<(&&q),0!VD#""1%(  #&a #%%a(+&&q$7+##A&)



#%$$R(*))"-/r   r  c                       \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " S\R                  R                  S9r\R                  " SSS	S
9r\R                   " S5      rSrg)r  i  a  The `Status` type defines a logical error model that is suitable for
different programming environments, including REST APIs and RPC APIs. It is
used by [gRPC](https://github.com/grpc). Each `Status` message contains
three pieces of data: error code, error message, and error details. You can
find out more about this error model and how to work with it in the [API
Design Guide](https://cloud.google.com/apis/design/errors).

Messages:
  DetailsValueListEntry: A DetailsValueListEntry object.

Fields:
  code: The status code, which should be an enum value of google.rpc.Code.
  details: A list of messages that carry the error details. There is a
    common set of message types for APIs to use.
  message: A developer-facing error message, which should be in English. Any
    user-facing error message should be localized and sent in the
    google.rpc.Status.details field, or localized by the client.
rn  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
Status.DetailsValueListEntryi  zA DetailsValueListEntry object.

Messages:
  AdditionalProperty: An additional property for a DetailsValueListEntry
    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)/Status.DetailsValueListEntry.AdditionalPropertyi  zAn additional property for a DetailsValueListEntry object.

Fields:
  key: Name of the additional property.
  value: A extra_types.JsonValue attribute.
r   r  r   r   Nr  r   r   r   ru  r    r  r   ru  r   Tr   r   Nrv  r   r   r   DetailsValueListEntryr    s4    		AY.. 	A %112FTXYr   r  r   r,   r   Tr   r   r   N)r   r   r   r   r   r   r{  r   rw  r  r1   r2   r3   r]  r.   r   r   messager   r   r   r   r  r    s|    & !!"89Zi// Z :Z2 
		9+<+<+B+B	C$""#:AM'!!!$'r   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)r   i   a  Additional information for subscription from Azure

Fields:
  subscriptionDisplayName: The Azure Subscription
    [displayName](https://learn.microsoft.com/en-
    us/rest/api/resources/subscriptions/list?view=rest-
    resources-2022-12-01&tabs=HTTP#examples) E.g.: My Test Subscription
  subscriptionResourceId: The Azure Subscription ID
    (https://learn.microsoft.com/en-
    us/rest/api/resources/subscriptions/list?view=rest-
    resources-2022-12-01&tabs=HTTP#examples) E.g.:
    /subscriptions/1a11aad8-de27-1234-85e9-0f675821f15c
r   r   r   N)
r   r   r   r   r   r   r   r   r   r   r   r   r   r   r      s+     &11!4$003r   r   c                       \ rS rSrSr\R                  " S5      r\R                  " S SSS9r	\R                  " S5      r
\R                  " S5      rS	rg
)TableFieldSchemai3  a  A field in TableSchema.

Fields:
  field: The field name. The name must contain only letters (a-z, A-Z),
    numbers (0-9), or underscores (_), and must start with a letter or
    underscore. The maximum length is 128 characters.
  fields: Describes the nested schema fields if the type property is set to
    RECORD.
  mode: The field mode. Possible values include NULLABLE, REQUIRED and
    REPEATED. The default value is NULLABLE.
  type: The field data type. Possible values include * STRING * BYTES *
    INTEGER * FLOAT * BOOLEAN * TIMESTAMP * DATE * TIME * DATETIME *
    GEOGRAPHY, * NUMERIC, * BIGNUMERIC, * RECORD (where RECORD indicates
    that the field contains a nested schema).
r   r   Tr   r   r   r   N)r   r   r   r   r   r   r   fieldr.   r  moder|  r   r   r   r   r  r  3  sN      


"%!!"4a$G&			q	!$			q	!$r   r  c                   <    \ rS rSrSr\R                  " SSSS9rSrg)	r  iJ  zVBigQuery Compatible table schema.

Fields:
  fields: Describes the fields in a table.
r  r   Tr   r   N)	r   r   r   r   r   r   r.   r  r   r   r   r   r  r  J  s     !!"4a$G&r   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  iT  a  The key and value for a [tag](https://cloud.google.com/resource-
manager/docs/tags/tags-overview).

Fields:
  tagKey: TagKey namespaced name, in the format of
    {ORG_ID}/{TAG_KEY_SHORT_NAME}.
  tagKeyId: TagKey ID, in the format of tagKeys/{TAG_KEY_ID}.
  tagValue: TagValue namespaced name, in the format of
    {ORG_ID}/{TAG_KEY_SHORT_NAME}/{TAG_VALUE_SHORT_NAME}.
  tagValueId: TagValue ID, in the format of tagValues/{TAG_VALUE_ID}.
r   r   r   r   r   N)r   r   r   r   r   r   r   tagKeytagKeyIdtagValue
tagValueIdr   r   r   r   r  r  T  sI    
   #&""1%(""1%($$Q'*r   r  c                   b    \ rS rSrSr\R                  " SS5      r\R                  " S5      r	Sr
g)TargetConnectionig  a  An other-cloud connection to verify before it gets created.

Fields:
  otherCloudConnection: The content of the connection.
  parent: The parent resource where this connection will be created. It can
    only be an organization number (such as "organizations/123") for now.
    Format: organizations/{organization_number} (e.g.,
    "organizations/123456"). This field is needed when
    non_existent_connection is set. Callers must have
    cloudasset.othercloudconnections.verify permission on the [parent].
rF  r   r   r   N)r   r   r   r   r   r   r.   rG  r   r  r   r   r   r   r  r  g  s-    
 #//0FJ  #&r   r  c                       \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	\R                  " S5      r\R                  " SS5      r\R                  " SS	5      r\R                  " S
S5      rSrg)r   ix  a)  An asset in Google Cloud and its temporal metadata, including the time
window when it was observed and its status during that window.

Enums:
  PriorAssetStateValueValuesEnum: State of prior_asset.

Fields:
  asset: An asset in Google Cloud.
  deleted: Whether the asset has been deleted or not.
  priorAsset: Prior copy of the asset. Populated if prior_asset_state is
    PRESENT. Currently this is only set for responses in Real-Time Feed.
  priorAssetState: State of prior_asset.
  window: The time window when the asset data and state was observed.
c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
,TemporalAsset.PriorAssetStateValueValuesEnumi  a.  State of prior_asset.

Values:
  PRIOR_ASSET_STATE_UNSPECIFIED: prior_asset is not applicable for the
    current asset.
  PRESENT: prior_asset is populated correctly.
  INVALID: Failed to set prior_asset.
  DOES_NOT_EXIST: Current asset is the first known state.
  DELETED: prior_asset is a deletion.
r   r   r   r   r   r   N)r   r   r   r   r   PRIOR_ASSET_STATE_UNSPECIFIEDPRESENTINVALIDDOES_NOT_EXISTr  r   r   r   r   PriorAssetStateValueValuesEnumr    s#    	 %&!GGNGr   r  rt   r   r   r   r   r  rh   r   N)r   r   r   r   r   r   r   r  r.   rr  rI   deleted
priorAssetr   priorAssetStatewindowr   r   r   r   r   r   x  sr    y~~ " 
 
 !
,%""1%'%%gq1*''(H!L/!!,2&r   r   c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)r   i  a  Additional information for tenant from Azure

Fields:
  tenantDisplayName: The Azure Tenant
    [displayName](https://learn.microsoft.com/en-
    us/rest/api/resources/tenants/list?view=rest-
    resources-2022-12-01&tabs=HTTP#examples) E.g.: Test_Display_Name
  tenantResourceId: The Azure Tenant ID (https://learn.microsoft.com/en-
    us/azure/azure-portal/get-subscription-tenant-id) E.g.:
    /tenants/a11aaa11-aa11-1aa1-11aa-1aaa11a
r   r   r   N)
r   r   r   r   r   r   r   r   r   r   r   r   r   r   r     s+    
  ++A.**1-r   r   c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)r  i  zA time window specified by its `start_time` and `end_time`.

Fields:
  endTime: End time of the time window (inclusive). If not specified, the
    current timestamp is used instead.
  startTime: Start time of the time window (exclusive).
r   r   r   N)
r   r   r   r   r   r   r   endTime	startTimer   r   r   r   r  r    s)     !!!$'##A&)r   r  c                   b    \ rS rSrSr\R                  " SS5      r\R                  " S5      r	Sr
g)r;  i  a  Update asset feed request.

Fields:
  feed: Required. The new values of feed details. It must match an existing
    feed and the field `name` must be in the format of:
    projects/project_number/feeds/feed_id or
    folders/folder_number/feeds/feed_id or
    organizations/organization_number/feeds/feed_id.
  updateMask: Required. Only updates the `feed` fields indicated by this
    mask. The field mask must not be empty, and it must not contain fields
    that are immutable or only set by the server.
r  r   r   r   N)r   r   r   r   r   r   r.   r  r   rS  r   r   r   r   r;  r;    s+     
			*$$$Q'*r   r;  c                   J   \ 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
5      r\R                  " S5      r\R                  " SS5      r\R                  " S5      rSrg)r  i  a  Validation result of the other-cloud connection.

Enums:
  ConnectionStateValueValuesEnum: NOTE: Deprecated The state of the other-
    cloud connection
  ConnectionStatusCategoryValueValuesEnum: Optional. The connection status
    Type.

Fields:
  additionalInfo: Required. The detailed information about the validation
    result.
  cause: Optional. Some further information about the connection. When the
    connection does not pass the Delegated Role validation, including
    Delegated Role assumption and listing accounts when auto-discovery is
    enabled, it will contain the detailed failure reasons. If the Delegated
    Role validation passes, this field will always contain the validated
    Collector account number. In addition, when the connection state is
    AWS_INVALID_COLLECTOR_ACCOUNTS, it will provide the valid Collector Role
    rate, and the detailed reasons for all invalid accounts. This field is
    parsed from the above CauseProto in JSON format.
  connectionState: NOTE: Deprecated The state of the other-cloud connection
  connectionStatus: Required. The status of the other-cloud connection with
    one of the following values VALID: If the connection is a AWS
    connection, it will be set as VALID if: the GCP Service Agent can be
    properly assumed to the AWS delegated role, the AWS Delegated Role can
    be assumed to the Collector Role, and the AWS Collector Role has
    required permissions; If the connection is an Azure connection, it will
    be set as VALID if: the GCP Service Agent can be properly assumed to the
    User-assigned Azure Managed Identity, and the Azure Managed Identity has
    required permissions. AWS_FAILED_TO_ASSUME_DELEGATED_ROLE: The
    connection is invalid because the GCP service agent can not be properly
    assumed to an AWS delegated role. AWS_FAILED_TO_LIST_ACCOUNTS: The
    connection is invalid because the APS auto-discovery is enabled and the
    permission to allow the Delegated Role to list accounts in the
    organization has not been set properly.
    AWS_ACTIVE_COLLECTOR_ACCOUNTS_NOT_FOUND: The connection is invalid
    because ACTIVE Collector accounts are not found. More details about the
    status of an AWS account can be found at https://docs.aws.amazon.com/org
    anizations/latest/APIReference/API_Account.html#organizations-Type-
    Account-Status AWS_INVALID_COLLECTOR_ACCOUNTS: The connection has
    invalid Collector accounts. A predefined threshold of the maximum number
    of invalid Collector accounts will be defined. When the number of
    invalid Collector accounts exceeds this limit, the validation will stop.
    The reason for one Collector account's invalidity can be one of the
    following values. The detailed reason will be included in the cause
    field. AWS_FAILED_TO_ASSUME_COLLECTOR_ROLE: The Delegated Role can not
    be properly assumed to the AWS Collector Role in the account.
    AWS_COLLECTOR_ROLE_POLICY_MISSING_REQUIRED_PERMISSION: The Collector
    Role misses required policy settings.
    AWS_FAILED_TO_CONNECT_TO_ORGNIZATIONS_SERVICE: The connection is invalid
    because the connection cannot connect to the AWS Organizations Service.
    This status is only applicable to connections with auto-discovery
    disabled. AZURE_ENABLED_SUBSCRIPTIONS_NOT_FOUND: The connection is
    invalid because Enabled subscriptions are not found in this connection.
    More details about SubscriptionState can be found at
    https://learn.microsoft.com/en-
    us/rest/api/resources/subscriptions/list?view=rest-
    resources-2022-12-01&tabs=HTTP#subscriptionstate
    AZURE_FAILED_TO_ASSUME_MANAGED_IDENTITY: Failed in assume the Azure
    Managed Identity with OCAI SA.
    AZURE_MANAGED_IDENTITY_MISSING_REQUIRED_PERMISSION: Azure Managed
    Identity missing required permissions. AZURE_MANAGED_IDENTITY_ASSUMPTION
    _FAILED_AND_MISSING_REQUIRED_PERMISSION: Azure Managed Identity
    assumption failed for one role type and missing required permissions for
    another role type. Role type can be either "Azure Role" or "Microsoft
    Entra Role".
  connectionStatusCategory: Optional. The connection status Type.
  validationTime: Required. The time when the connection was validated.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	/ValidationResult.ConnectionStateValueValuesEnumi  a2  NOTE: Deprecated The state of the other-cloud connection

Values:
  UNKNOWN: Unknown.
  VALID: The connection has been set up at AWS properly: the GCP Service
    Agent can be properly assumed to the AWS delegated role and then the
    AWS Collector role with required permissions.
  FAILED_TO_ASSUME_DELEGATED_ROLE: The connection is invalid because the
    GCP service agent can not be properly assumed to an AWS delegated
    role.
  INVALID_FOR_OTHER_REASON: The connection setting is invalid for other
    reasons. The detailed cause is in the cause field.
r   r   r   r   r   N)
r   r   r   r   r   rL  VALIDFAILED_TO_ASSUME_DELEGATED_ROLEINVALID_FOR_OTHER_REASONr   r   r   r   ConnectionStateValueValuesEnumr    s     GE&'# r   r  c                   0    \ rS rSrSrSrSrSrSrSr	Sr
S	rg
)8ValidationResult.ConnectionStatusCategoryValueValuesEnumi*  a  Optional. The connection status Type.

Values:
  CONNECTION_STATUS_CATEGORY_UNSPECIFIED: Unknown.
  CONNECTION_FULLY_OPERATIONAL: The connection has all required
    permissions, including the basic permission set and the permissions
    required for opted-in features. And there is no available but not yet
    opted-in features for this connection.
  CONNECTION_INOPERATIVE: The connection is inoperative, meaning it cannot
    be used to perform any actions. This is the case when the fundamental
    setup of the connection is broken.
  CONNECTION_PARTIALLY_INOPERATIVE: The connection is partially inoperable
    to perform some actions. For AWS, this means that part of the
    collector accounts are completely inoperable. For example, having
    AWS_FAILED_TO_ASSUME_COLLECTOR_ROLE status. For Azure, this means
    either Azure Role or Microsoft Entra Role is completely inoperable.
  CONNECTION_MISSING_EXPECTED_PERMISSIONS: The connection is missing
    required permissions, including the basic permission set and the
    permissions required for opted-in features.
  CONNECTION_MISSING_OPTIONAL_PERMISSIONS: The connection has all required
    permissions and is missing permissions required by available and not
    yet opted-in features.
r   r   r   r   r   rh   r   N)r   r   r   r   r   &CONNECTION_STATUS_CATEGORY_UNSPECIFIEDCONNECTION_FULLY_OPERATIONALCONNECTION_INOPERATIVE CONNECTION_PARTIALLY_INOPERATIVE'CONNECTION_MISSING_EXPECTED_PERMISSIONS'CONNECTION_MISSING_OPTIONAL_PERMISSIONSr   r   r   r   'ConnectionStatusCategoryValueValuesEnumr  *  s-    . ./*#$ '($./+./+r   r  r)   r   r   r   r   rh   ry   r   N)r   r   r   r   r   r   r   r  r  r.   additionalInfor   r\  r   connectionStateconnectionStatusconnectionStatusCategoryvalidationTimer   r   r   r   r  r    s    DL!y~~ !&0	 0> ))*:A>.



"%''(H!L/**1-&001Z\]^((+.r   r  c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)!VerifyOtherCloudConnectionRequestiQ  a  Request to verify an other-cloud connection.

Fields:
  name: The relative resource name of an other-cloud connection. Format: org
    anizations/{organization_number}/otherCloudConnections/{other_cloud_conn
    ection_id} currently "aws" and "azure" are allowed as the
    `other_cloud_connection_id`. E.g. -
    `organizations/123/otherCloudConnections/aws` -
    `organizations/123/otherCloudConnections/azure` This field will be used
    to validate the connection after its being created.
  targetConnection: An other-cloud connection to verify before its being
    created. A connection's name will not exist until the connection gets
    created. As a result, this field will be used to validate a connection
    before it exists.
r   r  r   r   N)r   r   r   r   r   r   r   r   r.   targetConnectionr   r   r   r   r  r  Q  s-      
		q	!$++,>Br   r  c                   >    \ rS rSrSr\R                  " SS5      rSrg)"VerifyOtherCloudConnectionResponseif  zResponse to verify an other-cloud connection.

Fields:
  validationResult: The validation result of the other-cloud connection.
r  r   r   N)	r   r   r   r   r   r   r.   validationResultr   r   r   r   r  r  f  s     ++,>Br   r  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S5      r	Sr
g)ry  ip  a%  Information related to the a standard versioned package. This includes
package info for APT, Yum, Zypper, and Googet package managers.

Fields:
  architecture: The system architecture this package is intended for.
  packageName: The name of the package.
  version: The version of the package.
r   r   r   r   N)r   r   r   r   r   r   r   r  packageNamer  r   r   r   r   ry  ry  p  s9     &&q),%%a(+!!!$'r   ry  c                       \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " SSSS	9r\R                  " SS
5      r\R                  " S5      rSrg)r   i  a  Resource representation as defined by the corresponding service
providing the resource for a given API version.

Messages:
  ResourceValue: JSON representation of the resource as defined by the
    corresponding service providing this resource. Example: If the resource
    is an instance provided by Compute Engine, this field will contain the
    JSON representation of the instance as defined by Compute Engine:
    `https://cloud.google.com/compute/docs/reference/rest/v1/instances`. You
    can find the resource definition for each supported resource type in
    this table: `https://cloud.google.com/asset-inventory/docs/supported-
    asset-types`

Fields:
  assetExceptions: The exceptions of a resource.
  resource: JSON representation of the resource as defined by the
    corresponding service providing this resource. Example: If the resource
    is an instance provided by Compute Engine, this field will contain the
    JSON representation of the instance as defined by Compute Engine:
    `https://cloud.google.com/compute/docs/reference/rest/v1/instances`. You
    can find the resource definition for each supported resource type in
    this table: `https://cloud.google.com/asset-inventory/docs/supported-
    asset-types`
  version: API version of the resource. Example: If the resource is an
    instance provided by Compute Engine v1 API as defined in
    `https://cloud.google.com/compute/docs/reference/rest/v1/instances`,
    version will be "v1".
rn  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
VersionedResource.ResourceValuei  aw  JSON representation of the resource as defined by the corresponding
service providing this resource. Example: If the resource is an instance
provided by Compute Engine, this field will contain the JSON
representation of the instance as defined by Compute Engine:
`https://cloud.google.com/compute/docs/reference/rest/v1/instances`. You
can find the resource definition for each supported resource type in this
table: `https://cloud.google.com/asset-inventory/docs/supported-asset-
types`

Messages:
  AdditionalProperty: An additional property for a ResourceValue 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)2VersionedResource.ResourceValue.AdditionalPropertyi  zAn additional property for a ResourceValue object.

Fields:
  key: Name of the additional property.
  value: A extra_types.JsonValue attribute.
r   r  r   r   Nr  r   r   r   ru  r    r  r   ru  r   Tr   r   Nrv  r   r   r   ResourceValuer    r  r   r  rw   r   Tr   r   r   r   N)r   r   r   r   r   r   r{  r   rw  r  r.   r   r   r   r  r   r   r   r   r   r     sp    : !!"89Zi'' Z :Z< **+;QN/##OQ7(!!!$'r   r   c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S5      r	\R                  " SS5      r\R                  " S5      rS	rg
)r{  i  a  Contains information about a Windows application that is retrieved from
the Windows Registry. For more information about these fields, see:
https://docs.microsoft.com/en-us/windows/win32/msi/uninstall-registry-key

Fields:
  displayName: The name of the application or product.
  displayVersion: The version of the product or application in string
    format.
  helpLink: The internet address for technical support.
  installDate: The last time this product received service. The value of
    this property is replaced each time a patch is applied or removed from
    the product or the command-line option is used to repair the product.
  publisher: The name of the manufacturer for the product or application.
r   r   r   r  r   rh   r   N)r   r   r   r   r   r   r   r0  displayVersionhelpLinkr.   installDate	publisherr   r   r   r   r{  r{    s[     %%a(+((+.""1%(&&vq1+##A&)r   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)	rz  i  a  Information related to a Quick Fix Engineering package. Fields are taken
from Windows QuickFixEngineering Interface and match the source names:
https://docs.microsoft.com/en-
us/windows/win32/cimwin32prov/win32-quickfixengineering

Fields:
  caption: A short textual description of the QFE update.
  description: A textual description of the QFE update.
  hotFixId: Unique identifier associated with a particular QFE update.
  installTime: Date that the QFE update was installed. Mapped from
    installed_on field.
r   r   r   r   r   N)r   r   r   r   r   r   r   captionr  hotFixIdinstallTimer   r   r   r   rz  rz    sI     !!!$'%%a(+""1%(%%a(+r   rz  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)WindowsUpdateCategoryi  zCategories specified by the Windows Update.

Fields:
  id: The identifier of the windows update category.
  name: The name of the windows update category.
r   r   r   N)
r   r   r   r   r   r   r   r  r   r   r   r   r   r  r    s)     Q"			q	!$r   r  c                   ~   \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	\R                  " SSS9r
\R                  " S	5      r\R                  " S
SS9r\R                  " S\R                  R                  S9r\R                  " S5      r\R                  " S5      r\R                  " S5      rSrg)r|  i  a  Details related to a Windows Update package. Field data and names are
taken from Windows Update API IUpdate Interface:
https://docs.microsoft.com/en-us/windows/win32/api/_wua/ Descriptive fields
like title, and description are localized based on the locale of the VM
being updated.

Fields:
  categories: The categories that are associated with this update package.
  description: The localized description of the update package.
  kbArticleIds: A collection of Microsoft Knowledge Base article IDs that
    are associated with the update package.
  lastDeploymentChangeTime: The last published date of the update, in (UTC)
    date and time.
  moreInfoUrls: A collection of URLs that provide more information about the
    update package.
  revisionNumber: The revision number of this update package.
  supportUrl: A hyperlink to the language-specific support information for
    the update.
  title: The localized title of the update package.
  updateId: Gets the identifier of an update package. Stays the same across
    revisions.
r  r   Tr   r   r   r   rh   ry   r,   rz   r|   r~   r   N)r   r   r   r   r   r   r.   
categoriesr   r  kbArticleIdslastDeploymentChangeTimemoreInfoUrlsr1   r2   r3   revisionNumber
supportUrlr  updateIdr   r   r   r   r|  r|    s    . %%&=q4P*%%a(+&&q48,&2215&&q48,))!Y5F5F5L5LM.$$Q'*



"%""1%(r   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  zDetails related to a Zypper Patch.

Fields:
  category: The category of the patch.
  patchName: The name of the patch.
  severity: The severity specified for this patch
  summary: Any summary information provided about this patch.
r   r   r   r   r   N)r   r   r   r   r   r   r   category	patchNameseverityr0   r   r   r   r   r}  r}    sI     ""1%(##A&)""1%(!!!$'r   r}  r  z$.xgafvr  1r  2rR  z!optInFeatures.allEligibleFeaturesr   z(analysisQuery.accessSelector.permissionsr   z"analysisQuery.accessSelector.rolesr   z)analysisQuery.conditionContext.accessTimer   z'analysisQuery.identitySelector.identityr   z8analysisQuery.options.analyzeServiceAccountImpersonationr   z"analysisQuery.options.expandGroupsr   z%analysisQuery.options.expandResourcesr   z!analysisQuery.options.expandRolesr   z/analysisQuery.options.includeDenyPolicyAnalysisr   z&analysisQuery.options.outputGroupEdgesr   z)analysisQuery.options.outputResourceEdgesr   z/analysisQuery.resourceSelector.fullResourceNamer$  zreadTimeWindow.endTimer%  zreadTimeWindow.startTimeN)r   
__future__r   apitools.base.protorpcliter   r   apitools.base.pyr   r   packagerw  r	   r   r$   r)   r6   r:   rB   rF   rN   rS   r[   r`   re   rU   rt   r   rw   r   r   r   r   r   r   r   r   r   r   r   r  r  r
  r  r   r'  r*  r.  r2  r6  r8  r:  r>  rC  rE  rJ  rM  rO  rQ  rU  rY  r^  r`  rb  rd  rf  rj  rm  r  r  r  r  r/  r  r  r  r   r  r  r  r  r+  r   r  r  r  r  r  r  r]   r  r  r  r%  rp   ro   rD  r  r  rF  rG  r  rV  rb   rY  r[  r-  ra  r	  rg   rd  rm  rq  rn  rt  ro  r  r  r{   r  rK  ru   rv   r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r   r  r   r  r*  rH   r=   r<   r0  r  r_  r9  r  r?  rf  r+   r}   r~  r  r  r  r  r   rP   r  r  r  r:  rV   r  rd  r  rF  r   r  r   r  rx   r  r  r  rV  r  r  r  r   r   r#  r%  r!  r   r   r   r0  r;  rZ  ry  ro  rs  r  rz  r  r  r  r   r  r  r  r  r   r   r  r;  r  r  r  ry  r   r{  rz  r  r|  r}  AddCustomJsonFieldMappingAddCustomJsonEnumMappingr  r   r   r   <module>r     s   ' < % ( 
("" 
("i "@2Y&& 2 OY&& O6()*;*; (0):): 04J)*;*; Jfy00 f&	J)++ 	JQ!2!2 Q"+Y->-> ++1B1B +  M	))  MF
V)"3"3 
VK)I K)\	?i'' 	?IY&& I4Uy(( U$%)## %:=Y&& =D;/	!! ;/|EI$5$5 EQ9+<+< Q?#)++ ?#DT"i T"n293D3D 2.K3	(9(9 K3\(79#4#4 (7V2)*;*; 2@*2i6G6G *2Z2):K:K 2BP>)"3"3 P>f;>Y->-> ;>|2I4E4E 243I$5$5 3 39#4#4 3"
19#4#4 
1
1	 1 1 
1
3!2!2 
3E)"3"3 E$G9#4#4 G1Y%6%6 1393D3D 3*	193D3D 	1	1	0A0A 	131B1B 30 ()2C2C  (FG9#4#4 G"*)*;*; *.
1)*;*; 
1
1y'8'8 
13	(9(9 3<():): ("S2I,=,= S2lD2)*;*; D2NR-Y.. R-j<&y00 <&~	(y(( 	(M)++ M:(%i (%V$	)) $"7I%% 70D9 D4k** k D** D2B)++ B0I 	Di// 	D8L)## 8LvE>)++ E>P!#9 !#H<A	)) <A~U>9 U>pEy(( E'Y&& '4"y00 " U)*;*;  UFOIL]L] O8!%PYPaPa !%H"%yO`O` "%J1.I,=,= 1.h)*;*; ("9#4#4 ("V<:):): <:~
"1B1B 
"Wi6G6G W$#gY5F5F #gL"93D3D ".93D3D .(Y.. (!y'8'8 !"(%)*;*; (%V"!2!2 ""VY%6%6 V(,y'8'8 ,$.9CTCT .0
.!2!2 
.GY.. GD	9Y%6%6 	9>)Y%6%6 >)B'I,=,= '<	hY->-> 	h"i6G6G "(B%	(9(9 B%J!')*;*; !'Hp,y'8'8 p,f%G9#4#4 %GP9+<+< e@)++ e@P#i6G6G #2%#y7H7H %#P)y7H7H )&%iY5F5F %iP,wI4E4E ,w^	+i6G6G 	+E0y7H7H E0PJiY5F5F JiZ#y7H7H #<&y7H7H &0!293D3D !2H/ji6G6G /jd#	8I8I #8&	8I8I &42I4E4E 20(9J9J ((6y7H7H (6VQ49;L;L Q4h&qARAR &qR0	@Q@Q 0$a9;L;L a=	8I8I =*Y	)) Y6	QI$5$5 	Q#Y.. #@Mi// M4C7Y.. C7L5&I-- 5&p&y(( &"	Di// 	D<** <	")++ 	"HKi// HKV8(	!! 8(v2(9 2(j&** & ;	)) ;[	(9(9 [
Hy00 
H7)++ 7&.9$$ .D** D $"" $i8	!! i8XM2i M2`%i'' %B%Y %6@:9,, @:F#S	)) #SL7S9,, 7St"9,, "@
?9$$ 
? GI%%  GF8)## 8KGY KG\
/"" 
/#	)) #ri// r.%** .%b9)++ 92	O9$$ 	O+()## +(\.9$$ .BOI%% O.i'' .Qy(( Q"Y.. ",A%y   A%H5	)) 5&;Y&& ;QV9,, QVh.y(( .<""" <"~	7y00 	7N9#4#4 N M!2!2 M (93D3D (&i.?.? &&"9i'' "9J<.i// <.~0%Y 0%f4y(( 4&"y(( ".H)## H()

 (&$y(( $"%3I%% %3P."" ."
'"" 
'(	)) ($~,y(( ~,BC	(9(9 C*C):): C%y(( %?%	)) ?%D'** '.)	(9(9 )(	"I-- 	" &9,,  &F%)## %  	 " "Z4  ! !114>  ! !114>  " "/1TVy{  " "%'QS}  " "%'KMqs  " "%'RTA  " "%'PR{}  " "%'a  d^_  " "%'KMqs  " "%'NPwy  " "%'JLoq  " "%'X  [LM  " "%'OQy{  " "%'RTA  " "%'X  [LM  " "*,DF^`  " "*,FHbdr   