
    ,                    L   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RX                  " \GSIGSJ5        \GRX                  " \GSKGSL5        \GRZ                  " \GR\                  GSMGSN5        \GRZ                  " \GR\                  GSOGSP5        \GRX                  " \EGSQGSR5        GgS(T  z8Generated message classes for gkehub version v1alpha1.

    )absolute_import)messages)encoding)extra_typesgkehubc                       \ rS rSrSrSrg)AppDevExperienceFeatureSpec   z$Spec for App Dev Experience Feature. N__name__
__module____qualname____firstlineno____doc____static_attributes__r       Ulib/googlecloudsdk/generated_clients/apis/gkehub/v1alpha1/gkehub_v1alpha1_messages.pyr	   r	      s    -r   r	   c                   >    \ rS rSrSr\R                  " SS5      rSrg)AppDevExperienceFeatureState   zState for App Dev Exp Feature.

Fields:
  networkingInstallSucceeded: Status of subcomponent that detects configured
    Service Mesh resources.
Status   r   N)	r   r   r   r   r   	_messagesMessageFieldnetworkingInstallSucceededr   r   r   r   r   r      s      )55hBr   r   c                   `    \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	Sr
g	)
AuditConfig   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   Trepeated   r   N)r   r   r   r   r   r   r   auditLogConfigsStringField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5      r\R                  " SS	5      rS
rg)r    <   a  Provides the configuration for logging a type of permissions. Example: {
"audit_log_configs": [ { "log_type": "DATA_READ", "exempted_members": [
"user:jose@example.com" ] }, { "log_type": "DATA_WRITE" } ] } This enables
'DATA_READ' and 'DATA_WRITE' logging, while exempting jose@example.com from
DATA_READ logging.

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

Fields:
  exemptedMembers: Specifies the identities that do not cause logging for
    this type of permission. Follows the same format of Binding.members.
  ignoreChildExemptions: A boolean attribute.
  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.LogTypeValueValuesEnumM   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   N)
r   r   r   r   r   LOG_TYPE_UNSPECIFIED
ADMIN_READ
DATA_WRITE	DATA_READr   r   r   r   LogTypeValueValuesEnumr*   M   s     JJIr   r1   r   Tr!   r#   r,   r   N)r   r   r   r   r   r   Enumr1   r%   exemptedMembersBooleanFieldignoreChildExemptions	EnumFieldlogTyper   r   r   r   r    r    <   sO     y~~  ))!d;/#003 8!<'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	5      r\R                  " S
S5      r\R                  " S5      r\R                  " SS5      rSrg)
AuthMethod`   a  Configuration of an auth method for a member/cluster. Only one
authentication method (e.g., OIDC and LDAP) can be set per AuthMethod.

Fields:
  azureadConfig: AzureAD specific configuration.
  googleConfig: GoogleConfig specific configuration
  ldapConfig: Optional. LDAP specific configuration.
  name: Identifier for auth config.
  oidcConfig: OIDC specific configuration.
  proxy: Proxy server address to use for auth method.
  samlConfig: Optional. SAML specific configuration.
AzureADConfigr   GoogleConfigr#   
LdapConfigr,      
OidcConfig      
SamlConfig   r   N)r   r   r   r   r   r   r   azureadConfiggoogleConfig
ldapConfigr%   name
oidcConfigproxy
samlConfigr   r   r   r   r9   r9   `   s     ((!<-'':,%%lA6*			q	!$%%lA6*



"%%%lA6*r   r9   c                   h    \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	Sr
g)AuthorizationLoggingOptionsw   zAuthorization-related information used by Cloud Audit Logging.

Enums:
  PermissionTypeValueValuesEnum: The type of the permission that was
    checked.

Fields:
  permissionType: The type of the permission that was checked.
c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
9AuthorizationLoggingOptions.PermissionTypeValueValuesEnum   a  The type of the permission that was checked.

Values:
  PERMISSION_TYPE_UNSPECIFIED: Default. Should not be used.
  ADMIN_READ: A read of admin (meta) data.
  ADMIN_WRITE: A write of admin (meta) data.
  DATA_READ: A read of standard data.
  DATA_WRITE: A write of standard data.
r   r   r#   r,   r>   r   Nr   r   r   r   r   PERMISSION_TYPE_UNSPECIFIEDr.   ADMIN_WRITEr0   r/   r   r   r   r   PermissionTypeValueValuesEnumrO      s#     #$JKIJr   rT   r   r   N)r   r   r   r   r   r   r2   rT   r6   permissionTyper   r   r   r   rL   rL   w   s,    inn   &&'FJ.r   rL   c                       \ rS rSrSrSrg)AuthorizerFeatureSpec   zVAuthorizerFeatureSpec contains options and specifications for the
Authorizer Feature.
r   Nr   r   r   r   rW   rW          r   rW   c                       \ rS rSrSrSrg)AuthorizerFeatureState   zVAuthorizerFeatureState contains the current detailed state of the
Authorizer Feature.
r   Nr   r   r   r   r[   r[      rY   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;      a  Configuration for the AzureAD Auth flow.

Fields:
  clientId: ID for the registered client application that makes
    authentication requests to the Azure AD identity provider.
  clientSecret: Input only. Unencrypted AzureAD client secret will be passed
    to the GKE Hub CLH.
  encryptedClientSecret: Output only. Encrypted AzureAD client secret.
  groupFormat: Optional. Format of the AzureAD groups that the client wants
    for auth.
  kubectlRedirectUri: The redirect URL that kubectl uses for authorization.
  tenant: Kind of Azure AD account to be authenticated. Supported values are
    or for accounts belonging to a specific tenant.
  userClaim: Optional. Claim in the AzureAD ID Token that holds the user
    details.
r   r#   r,   r>   r@   rA   rC   r   N)r   r   r   r   r   r   r%   clientIdclientSecret
BytesFieldencryptedClientSecretgroupFormatkubectlRedirectUritenant	userClaimr   r   r   r   r;   r;      s{    " ""1%(&&q),#..q1%%a(+ ,,Q/  #&##A&)r   r;   c                   <    \ rS rSrSr\R                  " S5      rSrg)BinauthzConfig   z\Configuration for Binauthz

Fields:
  enabled: Whether binauthz is enabled in this cluster.
r   r   N)	r   r   r   r   r   r   r4   enabledr   r   r   r   rh   rh      s     ""1%'r   rh   c                       \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	\R                  " SS5      rSrg	)
BinauthzState   zState for Binauthz

Enums:
  WebhookValueValuesEnum: The state of the binauthz webhook.

Fields:
  version: The version of binauthz that is installed.
  webhook: The state of the binauthz webhook.
c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
$BinauthzState.WebhookValueValuesEnum   a;  The state of the binauthz webhook.

Values:
  DEPLOYMENT_STATE_UNSPECIFIED: Deployment's state cannot be determined
  NOT_INSTALLED: Deployment is not installed
  INSTALLED: Deployment is installed
  ERROR: Deployment was attempted to be installed, but has errors
  PENDING: Deployment is installing or terminating
r   r   r#   r,   r>   r   Nr   r   r   r   r   DEPLOYMENT_STATE_UNSPECIFIEDNOT_INSTALLED	INSTALLEDERRORPENDINGr   r   r   r   WebhookValueValuesEnumro      #     $% MIEGr   rw   BinauthzVersionr   r#   r   N)r   r   r   r   r   r   r2   rw   r   versionr6   webhookr   r   r   r   rl   rl      s?    y~~   ""#4a8' 8!<'r   rl   c                   <    \ rS rSrSr\R                  " S5      rSrg)ry      zYThe version of binauthz.

Fields:
  webhookVersion: The version of the binauthz webhook.
r   r   N)	r   r   r   r   r   r   r%   webhookVersionr   r   r   r   ry   ry      s     ((+.r   ry   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S
rg)Binding   a  Associates `members`, or principals, with a `role`.

Fields:
  bindingId: A string attribute.
  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).
r   Exprr#   r,   Tr!   r>   r   N)r   r   r   r   r   r   r%   	bindingIdr   	conditionmembersroler   r   r   r   r   r      sO    Pd ##A&)$$VQ/)!!!d3'			q	!$r   r   c                   :    \ rS rSrSr\R                  " SSS9rSrg)BundleInstallSpeciJ  zBundleInstallSpec is the specification configuration for a single
managed bundle.

Fields:
  exemptedNamespaces: The set of namespaces to be exempted from the bundle.
r   Tr!   r   N)	r   r   r   r   r   r   r%   exemptedNamespacesr   r   r   r   r   r   J  s     !,,Q>r   r   c                       \ rS rSrSrSrg)CancelOperationRequestiU  z3The request message for Operations.CancelOperation.r   Nr   r   r   r   r   r   U  s    <r   r   c                   :    \ rS rSrSr\R                  " SSS9rSrg)CloudAuditLoggingFeatureSpeciY  a  Spec for Audit Logging Allowlisting.

Fields:
  allowlistedServiceAccounts: Service account that should be allowlisted to
    send the audit logs; eg cloudauditlogging@gcp-
    project.iam.gserviceaccount.com. These accounts must already exist, but
    do not need to have any permissions granted to them. The customer's
    entitlements will be checked prior to allowlisting (i.e. the customer
    must be an Anthos customer.)
r   Tr!   r   N)	r   r   r   r   r   r   r%   allowlistedServiceAccountsr   r   r   r   r   r   Y  s    	  )44QFr   r   c                       \ rS rSrSrSrg)CloudAuditLoggingFeatureStateih  zlAn empty state for Audit Logging Allowlisting. This is required since
FeatureStateDetails requires a state.
r   Nr   r   r   r   r   r   h  rY   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\R                  " SS
5      rSrg)CloudAuditOptionsio  a  Write a Cloud Audit log

Enums:
  LogNameValueValuesEnum: The log_name to populate in the Cloud Audit
    Record.
  PermissionTypeValueValuesEnum: The type associated with the permission.

Fields:
  authorizationLoggingOptions: Information used by the Cloud Audit Logging
    pipeline. Will be deprecated once the migration to PermissionType is
    complete (b/201806118).
  logName: The log_name to populate in the Cloud Audit Record.
  permissionType: The type associated with the permission.
c                   $    \ rS rSrSrSrSrSrSrg)(CloudAuditOptions.LogNameValueValuesEnumi  zThe log_name to populate in the Cloud Audit Record.

Values:
  UNSPECIFIED_LOG_NAME: Default. Should not be used.
  ADMIN_ACTIVITY: Corresponds to "cloudaudit.googleapis.com/activity"
  DATA_ACCESS: Corresponds to "cloudaudit.googleapis.com/data_access"
r   r   r#   r   N)	r   r   r   r   r   UNSPECIFIED_LOG_NAMEADMIN_ACTIVITYDATA_ACCESSr   r   r   r   LogNameValueValuesEnumr     s     NKr   r   c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
/CloudAuditOptions.PermissionTypeValueValuesEnumi  a  The type associated with the permission.

Values:
  PERMISSION_TYPE_UNSPECIFIED: Default. Should not be used.
  ADMIN_READ: Permissions that gate reading resource configuration or
    metadata.
  ADMIN_WRITE: Permissions that gate modification of resource
    configuration or metadata.
  DATA_READ: Permissions that gate reading user-provided data.
  DATA_WRITE: Permissions that gate writing user-provided data.
r   r   r#   r,   r>   r   NrQ   r   r   r   rT   r     s#    
 #$JKIJr   rT   rL   r   r#   r,   r   N)r   r   r   r   r   r   r2   r   rT   r   authorizationLoggingOptionsr6   logNamerU   r   r   r   r   r   r   o  sd    
y~~ 
inn $ !* 6 67TVW X 8!<'&&'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Srg)	CloudBuildFeatureSpeci  az  Cloud Build for Anthos feature spec. This is required since Feature
proto requires a spec.

Messages:
  MembershipConfigsValue: The map from membership path (e.g. projects/foo-
    proj/locations/global/memberships/bar) to the CloudBuildMembershipConfig
    that is chosen for that member cluster. If CloudBuild feature is enabled
    for a hub and the membership path of a cluster in that hub exists in
    this map then it has Cloud Build hub feature enabled for that particular
    cluster.

Fields:
  membershipConfigs: The map from membership path (e.g. projects/foo-
    proj/locations/global/memberships/bar) to the CloudBuildMembershipConfig
    that is chosen for that member cluster. If CloudBuild feature is enabled
    for a hub and the membership path of a cluster in that hub exists in
    this map then it has Cloud Build hub feature enabled for that particular
    cluster.
additionalPropertiesc                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
,CloudBuildFeatureSpec.MembershipConfigsValuei  a  The map from membership path (e.g. projects/foo-
proj/locations/global/memberships/bar) to the CloudBuildMembershipConfig
that is chosen for that member cluster. If CloudBuild feature is enabled
for a hub and the membership path of a cluster in that hub exists in this
map then it has Cloud Build hub feature enabled for that particular
cluster.

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

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

Fields:
  key: Name of the additional property.
  value: A CloudBuildMembershipConfig attribute.
r   CloudBuildMembershipConfigr#   r   Nr   r   r   r   r   r   r%   keyr   valuer   r   r   r   AdditionalPropertyr     s,    
 !!!$c$$%A1Eer   r   r   Tr!   r   Nr   r   r   r   r   r   Messager   r   r   r   r   r   r   MembershipConfigsValuer     s4     	FY.. 	F %112FTXYr   r   r   r   Nr   r   r   r   r   r   MapUnrecognizedFieldsr   r   r   r   membershipConfigsr   r   r   r   r   r     sM    ( !!"89Zy00 Z :Z<  ,,-EqIr   r   c                       \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	\R                  " S5      rSrg)	r   i  aT  Configurations for each Cloud Build enabled cluster.

Enums:
  SecurityPolicyValueValuesEnum: Whether it is allowed to run the privileged
    builds on the cluster or not.

Fields:
  securityPolicy: Whether it is allowed to run the privileged builds on the
    cluster or not.
  version: Version of the cloud build software on the cluster.
c                   $    \ rS rSrSrSrSrSrSrg)8CloudBuildMembershipConfig.SecurityPolicyValueValuesEnumi  zWhether it is allowed to run the privileged builds on the cluster or
not.

Values:
  SECURITY_POLICY_UNSPECIFIED: Unspecified policy
  NON_PRIVILEGED: Privileged build pods are disallowed
  PRIVILEGED: Privileged build pods are allowed
r   r   r#   r   N)	r   r   r   r   r   SECURITY_POLICY_UNSPECIFIEDNON_PRIVILEGED
PRIVILEGEDr   r   r   r   SecurityPolicyValueValuesEnumr     s     #$NJr   r   r   r#   r   N)r   r   r   r   r   r   r2   r   r6   securityPolicyr%   rz   r   r   r   r   r   r     s<    
inn  &&'FJ.!!!$'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	5      r\R                  " SS
5      rSrg)	Conditioni  a  Condition being reported.

Enums:
  CodeValueValuesEnum: Unique identifier of the condition which describes
    the condition recognizable to the user.
  SeverityValueValuesEnum: Severity level of the condition.

Fields:
  code: Unique identifier of the condition which describes the condition
    recognizable to the user.
  details: A short summary about the issue.
  documentationLink: Links contains actionable information.
  severity: Severity level of the condition.
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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+S*r,S+r-S,r.S-r/S.r0S/r1S0r2S1r3S2r4S3r5S4r6S5r7S6r8S7r9S8r:g9):Condition.CodeValueValuesEnumi  aZ  Unique identifier of the condition which describes the condition
recognizable to the user.

Values:
  CODE_UNSPECIFIED: Default Unspecified code
  MESH_IAM_PERMISSION_DENIED: Mesh IAM permission denied error code
  MESH_IAM_CROSS_PROJECT_PERMISSION_DENIED: Permission denied error code
    for cross-project
  CNI_CONFIG_UNSUPPORTED: CNI config unsupported error code
  GKE_SANDBOX_UNSUPPORTED: GKE sandbox unsupported error code
  NODEPOOL_WORKLOAD_IDENTITY_FEDERATION_REQUIRED: Nodepool workload
    identity federation required error code
  CNI_INSTALLATION_FAILED: CNI installation failed error code
  CNI_POD_UNSCHEDULABLE: CNI pod unschedulable error code
  CLUSTER_HAS_ZERO_NODES: Cluster has zero node code
  CANONICAL_SERVICE_ERROR: Failure to reconcile CanonicalServices
  UNSUPPORTED_MULTIPLE_CONTROL_PLANES: Multiple control planes unsupported
    error code
  VPCSC_GA_SUPPORTED: VPC-SC GA is supported for this control plane.
  DEPRECATED_SPEC_CONTROL_PLANE_MANAGEMENT: User is using deprecated
    ControlPlaneManagement and they have not yet set Management.
  DEPRECATED_SPEC_CONTROL_PLANE_MANAGEMENT_SAFE: User is using deprecated
    ControlPlaneManagement and they have already set Management.
  CONFIG_APPLY_INTERNAL_ERROR: Configuration (Istio/k8s resources) failed
    to apply due to internal error.
  CONFIG_VALIDATION_ERROR: Configuration failed to be applied due to being
    invalid.
  CONFIG_VALIDATION_WARNING: Encountered configuration(s) with possible
    unintended behavior or invalid configuration. These configs may not
    have been applied.
  QUOTA_EXCEEDED_BACKEND_SERVICES: BackendService quota exceeded error
    code.
  QUOTA_EXCEEDED_HEALTH_CHECKS: HealthCheck quota exceeded error code.
  QUOTA_EXCEEDED_HTTP_ROUTES: HTTPRoute quota exceeded error code.
  QUOTA_EXCEEDED_TCP_ROUTES: TCPRoute quota exceeded error code.
  QUOTA_EXCEEDED_TLS_ROUTES: TLS routes quota exceeded error code.
  QUOTA_EXCEEDED_TRAFFIC_POLICIES: TrafficPolicy quota exceeded error
    code.
  QUOTA_EXCEEDED_ENDPOINT_POLICIES: EndpointPolicy quota exceeded error
    code.
  QUOTA_EXCEEDED_GATEWAYS: Gateway quota exceeded error code.
  QUOTA_EXCEEDED_MESHES: Mesh quota exceeded error code.
  QUOTA_EXCEEDED_SERVER_TLS_POLICIES: ServerTLSPolicy quota exceeded error
    code.
  QUOTA_EXCEEDED_CLIENT_TLS_POLICIES: ClientTLSPolicy quota exceeded error
    code.
  QUOTA_EXCEEDED_SERVICE_LB_POLICIES: ServiceLBPolicy quota exceeded error
    code.
  QUOTA_EXCEEDED_HTTP_FILTERS: HTTPFilter quota exceeded error code.
  QUOTA_EXCEEDED_TCP_FILTERS: TCPFilter quota exceeded error code.
  QUOTA_EXCEEDED_NETWORK_ENDPOINT_GROUPS: NetworkEndpointGroup quota
    exceeded error code.
  LEGACY_MC_SECRETS: Legacy istio secrets found for multicluster error
    code
  WORKLOAD_IDENTITY_REQUIRED: Workload identity required error code
  NON_STANDARD_BINARY_USAGE: Non-standard binary usage error code
  UNSUPPORTED_GATEWAY_CLASS: Unsupported gateway class error code
  MANAGED_CNI_NOT_ENABLED: Managed CNI not enabled error code
  MODERNIZATION_SCHEDULED: Modernization is scheduled for a cluster.
  MODERNIZATION_IN_PROGRESS: Modernization is in progress for a cluster.
  MODERNIZATION_COMPLETED: Modernization is completed for a cluster.
  MODERNIZATION_ABORTED: Modernization is aborted for a cluster.
  MODERNIZATION_PREPARING: Preparing cluster so that its workloads can be
    migrated.
  MODERNIZATION_STALLED: Modernization is stalled for a cluster.
  MODERNIZATION_PREPARED: Cluster has been prepared for its workloads to
    be migrated.
  MODERNIZATION_MIGRATING_WORKLOADS: Migrating the cluster's workloads to
    the new implementation.
  MODERNIZATION_ROLLING_BACK_CLUSTER: Rollback is in progress for
    modernization of a cluster.
  MODERNIZATION_WILL_BE_SCHEDULED: Modernization will be scheduled for a
    fleet.
  MODERNIZATION_MANUAL: Fleet is opted out from automated modernization.
  MODERNIZATION_ELIGIBLE: Fleet is eligible for modernization.
  MODERNIZATION_MODERNIZING: Modernization of one or more clusters in a
    fleet is in progress.
  MODERNIZATION_MODERNIZED_SOAKING: Modernization of all the fleet's
    clusters is complete. Soaking before finalizing the modernization.
  MODERNIZATION_FINALIZED: Modernization is finalized for all clusters in
    a fleet. Rollback is no longer allowed.
  MODERNIZATION_ROLLING_BACK_FLEET: Rollback is in progress for
    modernization of all clusters in a fleet.
r   r   r#   r,   r>   r@   rA   rC      	   
                  r
            r                                 r       !   "   #   $   %   &   '   (   )   *   +   ,   -   .   /   0   1   2   3   4   r   N);r   r   r   r   r   CODE_UNSPECIFIEDMESH_IAM_PERMISSION_DENIED(MESH_IAM_CROSS_PROJECT_PERMISSION_DENIEDCNI_CONFIG_UNSUPPORTEDGKE_SANDBOX_UNSUPPORTED.NODEPOOL_WORKLOAD_IDENTITY_FEDERATION_REQUIREDCNI_INSTALLATION_FAILEDCNI_POD_UNSCHEDULABLECLUSTER_HAS_ZERO_NODESCANONICAL_SERVICE_ERROR#UNSUPPORTED_MULTIPLE_CONTROL_PLANESVPCSC_GA_SUPPORTED(DEPRECATED_SPEC_CONTROL_PLANE_MANAGEMENT-DEPRECATED_SPEC_CONTROL_PLANE_MANAGEMENT_SAFECONFIG_APPLY_INTERNAL_ERRORCONFIG_VALIDATION_ERRORCONFIG_VALIDATION_WARNINGQUOTA_EXCEEDED_BACKEND_SERVICESQUOTA_EXCEEDED_HEALTH_CHECKSQUOTA_EXCEEDED_HTTP_ROUTESQUOTA_EXCEEDED_TCP_ROUTESQUOTA_EXCEEDED_TLS_ROUTESQUOTA_EXCEEDED_TRAFFIC_POLICIES QUOTA_EXCEEDED_ENDPOINT_POLICIESQUOTA_EXCEEDED_GATEWAYSQUOTA_EXCEEDED_MESHES"QUOTA_EXCEEDED_SERVER_TLS_POLICIES"QUOTA_EXCEEDED_CLIENT_TLS_POLICIES"QUOTA_EXCEEDED_SERVICE_LB_POLICIESQUOTA_EXCEEDED_HTTP_FILTERSQUOTA_EXCEEDED_TCP_FILTERS&QUOTA_EXCEEDED_NETWORK_ENDPOINT_GROUPSLEGACY_MC_SECRETSWORKLOAD_IDENTITY_REQUIREDNON_STANDARD_BINARY_USAGEUNSUPPORTED_GATEWAY_CLASSMANAGED_CNI_NOT_ENABLEDMODERNIZATION_SCHEDULEDMODERNIZATION_IN_PROGRESSMODERNIZATION_COMPLETEDMODERNIZATION_ABORTEDMODERNIZATION_PREPARINGMODERNIZATION_STALLEDMODERNIZATION_PREPARED!MODERNIZATION_MIGRATING_WORKLOADS"MODERNIZATION_ROLLING_BACK_CLUSTERMODERNIZATION_WILL_BE_SCHEDULEDMODERNIZATION_MANUALMODERNIZATION_ELIGIBLEMODERNIZATION_MODERNIZING MODERNIZATION_MODERNIZED_SOAKINGMODERNIZATION_FINALIZED MODERNIZATION_ROLLING_BACK_FLEETr   r   r   r   CodeValueValuesEnumr     sI   Sh !"/0,562*,'/1,461"$  "&(##% !# " "&(#')$ )+&)+&)+&"$!#-/*!# " "   "  (*%)+&&(# "')$ ')$r   r  c                   (    \ rS rSrSrSrSrSrSrSr	g)	!Condition.SeverityValueValuesEnumi  a<  Severity level of the condition.

Values:
  SEVERITY_UNSPECIFIED: Unspecified severity
  ERROR: Indicates an issue that prevents the mesh from operating
    correctly
  WARNING: Indicates a setting is likely wrong, but the mesh is still able
    to operate
  INFO: An informational message, not requiring any action
r   r   r#   r,   r   N)
r   r   r   r   r   SEVERITY_UNSPECIFIEDru   WARNINGINFOr   r   r   r   SeverityValueValuesEnumr    s    	 EGDr   r   r   r#   r,   r>   r   N)r   r   r   r   r   r   r2   r  r   r6   coder%   detailsdocumentationLinkseverityr   r   r   r   r   r     ss    I*INN I*V	   
		2A	6$!!!$'++A.  !:A>(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)	ConfigManagementFeatureSpeci  zSpec for Anthos Config Management (ACM).

Messages:
  MembershipConfigsValue: Map of Membership IDs to individual configs.

Fields:
  membershipConfigs: Map of Membership IDs to individual configs.
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	)
2ConfigManagementFeatureSpec.MembershipConfigsValuei  zMap of Membership IDs to individual configs.

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

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

Fields:
  key: Name of the additional property.
  value: A MembershipConfig attribute.
r   MembershipConfigr#   r   Nr   r   r   r   r   r*    s,    
 !!!$c$$%7;er   r   r   Tr!   r   Nr   r   r   r   r   r(    s2    		<Y.. 	< %112FTXYr   r   r   r   Nr   r   r   r   r&  r&    sM     !!"89Zy00 Z :Z2  ,,-EqIr   r&  c                   D   \ rS rSrSr\R                  " SS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\R                  " SS5      r\R                  " SS5      rSrg)ConfigManagementFeatureStatei  a  State for Anthos Config Management

Fields:
  binauthzState: Binauthz status
  clusterName: This field is set to the `cluster_name` field of the
    Membership Spec if it is not empty. Otherwise, it is set to the
    cluster's fleet membership name.
  configSyncState: Current sync status
  hierarchyControllerState: Hierarchy Controller status
  kubernetesApiServerVersion: Output only. The Kubernetes API server version
    of the cluster.
  membershipConfig: Membership configuration in the cluster. This represents
    the actual state in the cluster, while the MembershipConfig in the
    FeatureSpec represents the intended state
  operatorState: Current install status of ACM's Operator
  policyControllerState: PolicyController status
rl   r   r#   ConfigSyncStater,   HierarchyControllerStater>   r@   r+  rA   OperatorStaterC   PolicyControllerStater   r   N)r   r   r   r   r   r   r   binauthzStater%   clusterNameconfigSyncStatehierarchyControllerStatekubernetesApiServerVersionmembershipConfigoperatorStatepolicyControllerStater   r   r   r   r-  r-    s    $ ((!<-%%a(+**+<a@/&334NPQR(44Q7++,>B((!<-#001H!Lr   r-  c                   <   \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	\R                  " S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)
ConfigSynci  a  Configuration for Config Sync

Fields:
  deploymentOverrides: Optional. Configuration for deployment overrides.
  enabled: Enables the installation of ConfigSync. If set to true,
    ConfigSync resources will be created and the other ConfigSync fields
    will be applied if exist. If set to false, all other ConfigSync fields
    will be ignored, ConfigSync resources will be deleted. If omitted,
    ConfigSync resources will be managed depends on the presence of the git
    or oci field.
  git: Git repo configuration for the cluster.
  metricsGcpServiceAccountEmail: The Email of the Google Cloud Service
    Account (GSA) used for exporting Config Sync metrics to Cloud Monitoring
    and Cloud Monarch when Workload Identity is enabled. The GSA should have
    the Monitoring Metric Writer (roles/monitoring.metricWriter) IAM role.
    The Kubernetes ServiceAccount `default` in the namespace `config-
    management-monitoring` should be bound to the GSA. Deprecated: If
    Workload Identity Federation for GKE is enabled, Google Cloud Service
    Account is no longer needed for exporting Config Sync metrics:
    https://cloud.google.com/kubernetes-engine/enterprise/config-
    sync/docs/how-to/monitor-config-sync-cloud-monitoring#custom-monitoring.
  oci: OCI repo configuration for the cluster
  preventDrift: Set to true to enable the Config Sync admission webhook to
    prevent drifts. Defaults to false which disables the Config Sync
    admission webhook and does not prevent drifts.
  sourceFormat: Specifies whether the Config Sync Repo is in "hierarchical"
    or "unstructured" mode.
  stopSyncing: Set to true to stop syncing configs for a single cluster.
    Default to false.
DeploymentOverrider   Tr!   r#   	GitConfigr,   r>   	OciConfigr@   rA   rC   r   r   N)r   r   r   r   r   r   r   deploymentOverridesr4   rj   gitr%   metricsGcpServiceAccountEmailocipreventDriftsourceFormatstopSyncingr   r   r   r   r;  r;    s    > "../CQQUV""1%'{A.#"+"7"7":{A.#''*,&&q),&&q)+r   r;  c                      \ rS rS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\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) ConfigSyncDeploymentStatei  a  The state of ConfigSync's deployment on a cluster

Enums:
  AdmissionWebhookValueValuesEnum: Deployment state of admission-webhook
  GitSyncValueValuesEnum: Deployment state of the git-sync pod
  ImporterValueValuesEnum: Deployment state of the importer pod
  MonitorValueValuesEnum: Deployment state of the monitor pod
  OtelCollectorValueValuesEnum: Deployment state of otel-collector
  ReconcilerManagerValueValuesEnum: Deployment state of reconciler-manager
    pod
  ResourceGroupControllerManagerValueValuesEnum: Deployment state of
    resource-group-controller-manager
  RootReconcilerValueValuesEnum: Deployment state of root-reconciler
  SyncerValueValuesEnum: Deployment state of the syncer pod

Fields:
  admissionWebhook: Deployment state of admission-webhook
  gitSync: Deployment state of the git-sync pod
  importer: Deployment state of the importer pod
  monitor: Deployment state of the monitor pod
  otelCollector: Deployment state of otel-collector
  reconcilerManager: Deployment state of reconciler-manager pod
  resourceGroupControllerManager: Deployment state of resource-group-
    controller-manager
  rootReconciler: Deployment state of root-reconciler
  syncer: Deployment state of the syncer pod
c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
9ConfigSyncDeploymentState.AdmissionWebhookValueValuesEnumi3  a>  Deployment state of admission-webhook

Values:
  DEPLOYMENT_STATE_UNSPECIFIED: Deployment's state cannot be determined
  NOT_INSTALLED: Deployment is not installed
  INSTALLED: Deployment is installed
  ERROR: Deployment was attempted to be installed, but has errors
  PENDING: Deployment is installing or terminating
r   r   r#   r,   r>   r   Nrq   r   r   r   AdmissionWebhookValueValuesEnumrI  3  rx   r   rJ  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
0ConfigSyncDeploymentState.GitSyncValueValuesEnumiC  a=  Deployment state of the git-sync pod

Values:
  DEPLOYMENT_STATE_UNSPECIFIED: Deployment's state cannot be determined
  NOT_INSTALLED: Deployment is not installed
  INSTALLED: Deployment is installed
  ERROR: Deployment was attempted to be installed, but has errors
  PENDING: Deployment is installing or terminating
r   r   r#   r,   r>   r   Nrq   r   r   r   GitSyncValueValuesEnumrL  C  rx   r   rM  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
1ConfigSyncDeploymentState.ImporterValueValuesEnumiS  a=  Deployment state of the importer pod

Values:
  DEPLOYMENT_STATE_UNSPECIFIED: Deployment's state cannot be determined
  NOT_INSTALLED: Deployment is not installed
  INSTALLED: Deployment is installed
  ERROR: Deployment was attempted to be installed, but has errors
  PENDING: Deployment is installing or terminating
r   r   r#   r,   r>   r   Nrq   r   r   r   ImporterValueValuesEnumrO  S  rx   r   rP  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
0ConfigSyncDeploymentState.MonitorValueValuesEnumic  a<  Deployment state of the monitor pod

Values:
  DEPLOYMENT_STATE_UNSPECIFIED: Deployment's state cannot be determined
  NOT_INSTALLED: Deployment is not installed
  INSTALLED: Deployment is installed
  ERROR: Deployment was attempted to be installed, but has errors
  PENDING: Deployment is installing or terminating
r   r   r#   r,   r>   r   Nrq   r   r   r   MonitorValueValuesEnumrR  c  rx   r   rS  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
6ConfigSyncDeploymentState.OtelCollectorValueValuesEnumis  a;  Deployment state of otel-collector

Values:
  DEPLOYMENT_STATE_UNSPECIFIED: Deployment's state cannot be determined
  NOT_INSTALLED: Deployment is not installed
  INSTALLED: Deployment is installed
  ERROR: Deployment was attempted to be installed, but has errors
  PENDING: Deployment is installing or terminating
r   r   r#   r,   r>   r   Nrq   r   r   r   OtelCollectorValueValuesEnumrU  s  rx   r   rV  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
:ConfigSyncDeploymentState.ReconcilerManagerValueValuesEnumi  aC  Deployment state of reconciler-manager pod

Values:
  DEPLOYMENT_STATE_UNSPECIFIED: Deployment's state cannot be determined
  NOT_INSTALLED: Deployment is not installed
  INSTALLED: Deployment is installed
  ERROR: Deployment was attempted to be installed, but has errors
  PENDING: Deployment is installing or terminating
r   r   r#   r,   r>   r   Nrq   r   r   r    ReconcilerManagerValueValuesEnumrX    rx   r   rY  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
GConfigSyncDeploymentState.ResourceGroupControllerManagerValueValuesEnumi  aN  Deployment state of resource-group-controller-manager

Values:
  DEPLOYMENT_STATE_UNSPECIFIED: Deployment's state cannot be determined
  NOT_INSTALLED: Deployment is not installed
  INSTALLED: Deployment is installed
  ERROR: Deployment was attempted to be installed, but has errors
  PENDING: Deployment is installing or terminating
r   r   r#   r,   r>   r   Nrq   r   r   r   -ResourceGroupControllerManagerValueValuesEnumr[    rx   r   r\  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
7ConfigSyncDeploymentState.RootReconcilerValueValuesEnumi  a<  Deployment state of root-reconciler

Values:
  DEPLOYMENT_STATE_UNSPECIFIED: Deployment's state cannot be determined
  NOT_INSTALLED: Deployment is not installed
  INSTALLED: Deployment is installed
  ERROR: Deployment was attempted to be installed, but has errors
  PENDING: Deployment is installing or terminating
r   r   r#   r,   r>   r   Nrq   r   r   r   RootReconcilerValueValuesEnumr^    rx   r   r_  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
/ConfigSyncDeploymentState.SyncerValueValuesEnumi  a;  Deployment state of the syncer pod

Values:
  DEPLOYMENT_STATE_UNSPECIFIED: Deployment's state cannot be determined
  NOT_INSTALLED: Deployment is not installed
  INSTALLED: Deployment is installed
  ERROR: Deployment was attempted to be installed, but has errors
  PENDING: Deployment is installing or terminating
r   r   r#   r,   r>   r   Nrq   r   r   r   SyncerValueValuesEnumra    rx   r   rb  r   r#   r,   r>   r@   rA   rC   r   r   r   N)r   r   r   r   r   r   r2   rJ  rM  rP  rS  rV  rY  r\  r_  rb  r6   admissionWebhookgitSyncimportermonitorotelCollectorreconcilerManagerresourceGroupControllerManagerrootReconcilersyncerr   r   r   r   rG  rG    sH   8	  y~~  	  y~~  Y^^    inn  inn  inn   (()JAN 8!<'  !:A>( 8!<'%%&DaH-))*LaP#,#6#67fhi#j &&'FJ.6:&r   rG  c                   <    \ rS rSrSr\R                  " S5      rSrg)ConfigSyncErrori  zErrors pertaining to the installation of Config Sync

Fields:
  errorMessage: A string representing the user facing error message
r   r   N	r   r   r   r   r   r   r%   errorMessager   r   r   r   rm  rm         &&q),r   rm  c                   8   \ rS rSrSr " S S\R                  5      r " S S\R                  5      r " S S\R                  5      r	 " S	 S
\R                  5      r
\R                  " SS5      r\R                  " S\R                  R                  S9r\R"                  " S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Srg)r.  i  a0  State information for ConfigSync

Enums:
  ClusterLevelStopSyncingStateValueValuesEnum: Whether syncing resources to
    the cluster is stopped at the cluster level.
  ReposyncCrdValueValuesEnum: The state of the Reposync CRD
  RootsyncCrdValueValuesEnum: The state of the RootSync CRD
  StateValueValuesEnum: The state of CS This field summarizes the other
    fields in this message.

Fields:
  clusterLevelStopSyncingState: Whether syncing resources to the cluster is
    stopped at the cluster level.
  crCount: Output only. The number of RootSync and RepoSync CRs in the
    cluster.
  deploymentState: Information about the deployment of ConfigSync, including
    the version of the various Pods deployed
  errors: Errors pertaining to the installation of Config Sync.
  reposyncCrd: The state of the Reposync CRD
  rootsyncCrd: The state of the RootSync CRD
  state: The state of CS This field summarizes the other fields in this
    message.
  syncState: The state of ConfigSync's process to sync configs to a cluster
  version: The version of ConfigSync deployed
c                   (    \ rS rSrSrSrSrSrSrSr	g)	;ConfigSyncState.ClusterLevelStopSyncingStateValueValuesEnumi  a  Whether syncing resources to the cluster is stopped at the cluster
level.

Values:
  STOP_SYNCING_STATE_UNSPECIFIED: State cannot be determined
  NOT_STOPPED: Syncing resources to the cluster is not stopped at the
    cluster level.
  PENDING: Some reconcilers stop syncing resources to the cluster, while
    others are still syncing.
  STOPPED: Syncing resources to the cluster is stopped at the cluster
    level.
r   r   r#   r,   r   N)
r   r   r   r   r   STOP_SYNCING_STATE_UNSPECIFIEDNOT_STOPPEDrv   STOPPEDr   r   r   r   +ClusterLevelStopSyncingStateValueValuesEnumrs    s     &'"KGGr   rw  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
*ConfigSyncState.ReposyncCrdValueValuesEnumi  a  The state of the Reposync CRD

Values:
  CRD_STATE_UNSPECIFIED: CRD's state cannot be determined
  NOT_INSTALLED: CRD is not installed
  INSTALLED: CRD is installed
  TERMINATING: CRD is terminating (i.e., it has been deleted and is
    cleaning up)
  INSTALLING: CRD is installing
r   r   r#   r,   r>   r   Nr   r   r   r   r   CRD_STATE_UNSPECIFIEDrs   rt   TERMINATING
INSTALLINGr   r   r   r   ReposyncCrdValueValuesEnumry    #    	 MIKJr   r~  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
*ConfigSyncState.RootsyncCrdValueValuesEnumi  a  The state of the RootSync CRD

Values:
  CRD_STATE_UNSPECIFIED: CRD's state cannot be determined
  NOT_INSTALLED: CRD is not installed
  INSTALLED: CRD is installed
  TERMINATING: CRD is terminating (i.e., it has been deleted and is
    cleaning up)
  INSTALLING: CRD is installing
r   r   r#   r,   r>   r   Nrz  r   r   r   RootsyncCrdValueValuesEnumr    r  r   r  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
$ConfigSyncState.StateValueValuesEnumi'  al  The state of CS This field summarizes the other fields in this
message.

Values:
  STATE_UNSPECIFIED: CS's state cannot be determined.
  CONFIG_SYNC_NOT_INSTALLED: CS is not installed.
  CONFIG_SYNC_INSTALLED: The expected CS version is installed
    successfully.
  CONFIG_SYNC_ERROR: CS encounters errors.
  CONFIG_SYNC_PENDING: CS is installing or terminating.
r   r   r#   r,   r>   r   N)r   r   r   r   r   STATE_UNSPECIFIEDCONFIG_SYNC_NOT_INSTALLEDCONFIG_SYNC_INSTALLEDCONFIG_SYNC_ERRORCONFIG_SYNC_PENDINGr   r   r   r   StateValueValuesEnumr  '  s'    
  !r   r  r   r#   variantrG  r,   rm  r>   Tr!   r@   rA   rC   	SyncStater   ConfigSyncVersionr   r   N)r   r   r   r   r   r   r2   rw  r~  r  r  r6   clusterLevelStopSyncingStateIntegerFieldVariantINT32crCountr   deploymentStateerrorsreposyncCrdrootsyncCrdstate	syncStaterz   r   r   r   r   r.  r.    s   4INN $9>> "9>> "Y^^ $ "+!4!45bde!f""1i.?.?.E.EF'**+FJ/!!"3QF&##$@!D+##$@!D+


4a
8%$$[!4)""#6:'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\R                  " S
5      r\R                  " S5      rSrg)r  iD  a  Specific versioning information pertaining to ConfigSync's Pods

Fields:
  admissionWebhook: Version of the deployed admission-webhook pod
  gitSync: Version of the deployed git-sync pod
  importer: Version of the deployed importer pod
  monitor: Version of the deployed monitor pod
  otelCollector: Version of the deployed otel-collector pod
  reconcilerManager: Version of the deployed reconciler-manager pod
  resourceGroupControllerManager: Version of the deployed resource-group-
    controller-manager pod
  rootReconciler: Version of the deployed reconciler container in root-
    reconciler pod
  syncer: Version of the deployed syncer pod
r   r#   r,   r>   r@   rA   rC   r   r   r   N)r   r   r   r   r   r   r%   rc  rd  re  rf  rg  rh  ri  rj  rk  r   r   r   r   r  r  D  s      **1-!!!$'""1%(!!!$'''*-++A.#,#8#8#; ((+.  #&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Srg	)
ContainerOverridei`  a+  Configuration for a container override.

Fields:
  containerName: Required. The name of the container.
  cpuLimit: The cpu limit of the container.
  cpuRequest: The cpu request of the container.
  memoryLimit: The memory limit of the container.
  memoryRequest: The memory request of the container.
r   r#   r,   r>   r@   r   N)r   r   r   r   r   r   r%   containerNamecpuLimit
cpuRequestmemoryLimitmemoryRequestr   r   r   r   r  r  `  sY     ''*-""1%($$Q'*%%a(+''*-r   r  c                       \ 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5      r\R                  " SS5      rSrg)ControlPlaneManagementir  az  Status of control plane management. Only reported per-member.

Enums:
  ImplementationValueValuesEnum: Output only. Implementation of managed
    control plane.
  StateValueValuesEnum: State of control plane management.

Fields:
  details: Explanation of state.
  implementation: Output only. Implementation of managed control plane.
  state: State of control plane management.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	4ControlPlaneManagement.ImplementationValueValuesEnumi  aB  Output only. Implementation of managed control plane.

Values:
  IMPLEMENTATION_UNSPECIFIED: Unspecified
  ISTIOD: A Google build of istiod is used for the managed control plane.
  TRAFFIC_DIRECTOR: Traffic director is used for the managed control
    plane.
  UPDATING: The control plane implementation is being updated.
r   r   r#   r,   r   N)
r   r   r   r   r   IMPLEMENTATION_UNSPECIFIEDISTIODTRAFFIC_DIRECTORUPDATINGr   r   r   r   ImplementationValueValuesEnumr    s     "#FHr   r  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g)+ControlPlaneManagement.StateValueValuesEnumi  aV  State of control plane management.

Values:
  LIFECYCLE_STATE_UNSPECIFIED: Unspecified
  DISABLED: DISABLED means that the component is not enabled.
  FAILED_PRECONDITION: FAILED_PRECONDITION means that provisioning cannot
    proceed because of some characteristic of the member cluster.
  PROVISIONING: PROVISIONING means that provisioning is in progress.
  ACTIVE: ACTIVE means that the component is ready for use.
  STALLED: STALLED means that provisioning could not be done.
  NEEDS_ATTENTION: NEEDS_ATTENTION means that the component is ready, but
    some user intervention is required. (For example that the user should
    migrate workloads to a new control plane revision.)
  DEGRADED: DEGRADED means that the component is ready, but operating in a
    degraded state.
  DEPROVISIONING: DEPROVISIONING means that deprovisioning is in progress.
r   r   r#   r,   r>   r@   rA   rC   r   r   Nr   r   r   r   r   LIFECYCLE_STATE_UNSPECIFIEDDISABLEDFAILED_PRECONDITIONPROVISIONINGACTIVESTALLEDNEEDS_ATTENTIONDEGRADEDDEPROVISIONINGr   r   r   r   r  r    8    " #$HLFGOHNr   r  StatusDetailsr   Tr!   r#   r,   r   N)r   r   r   r   r   r   r2   r  r  r   r"  r6   implementationr  r   r   r   r   r  r  r  sc    inn Y^^ 8 ""?AE'&&'FJ.


4a
8%r   r  c                      \ rS rSrSr " S S\R                  5      r " S S\R                  5      r " S S\R                  5      r	\R                  " S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S5      r\R                  " S5      rSrg)ControlPlaneRevisioni  a  Status of a control plane revision that is intended to be available for
use in the cluster.

Enums:
  ChannelValueValuesEnum: Release Channel the managed control plane revision
    is subscribed to.
  StateValueValuesEnum: State of the control plane revision.
    LIFECYCLE_STATE_UNSPECIFIED, FAILED_PRECONDITION, PROVISIONING, ACTIVE,
    and STALLED are applicable here.
  TypeValueValuesEnum: Type of the control plane revision.

Fields:
  channel: Release Channel the managed control plane revision is subscribed
    to.
  details: Explanation of the state.
  owner: Owner of the control plane revision.
  revision: Unique name of the control plane revision.
  state: State of the control plane revision. LIFECYCLE_STATE_UNSPECIFIED,
    FAILED_PRECONDITION, PROVISIONING, ACTIVE, and STALLED are applicable
    here.
  type: Type of the control plane revision.
  version: Static version of the control plane revision.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	+ControlPlaneRevision.ChannelValueValuesEnumi  a  Release Channel the managed control plane revision is subscribed to.

Values:
  CHANNEL_UNSPECIFIED: Unspecified
  RAPID: RAPID channel is offered on an early access basis for customers
    who want to test new releases.
  REGULAR: REGULAR channel is intended for production users who want to
    take advantage of new features.
  STABLE: STABLE channel includes versions that are known to be stable and
    reliable in production.
r   r   r#   r,   r   N
r   r   r   r   r   CHANNEL_UNSPECIFIEDRAPIDREGULARSTABLEr   r   r   r   ChannelValueValuesEnumr        
 EGFr   r  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g))ControlPlaneRevision.StateValueValuesEnumi  a  State of the control plane revision. LIFECYCLE_STATE_UNSPECIFIED,
FAILED_PRECONDITION, PROVISIONING, ACTIVE, and STALLED are applicable
here.

Values:
  LIFECYCLE_STATE_UNSPECIFIED: Unspecified
  DISABLED: DISABLED means that the component is not enabled.
  FAILED_PRECONDITION: FAILED_PRECONDITION means that provisioning cannot
    proceed because of some characteristic of the member cluster.
  PROVISIONING: PROVISIONING means that provisioning is in progress.
  ACTIVE: ACTIVE means that the component is ready for use.
  STALLED: STALLED means that provisioning could not be done.
  NEEDS_ATTENTION: NEEDS_ATTENTION means that the component is ready, but
    some user intervention is required. (For example that the user should
    migrate workloads to a new control plane revision.)
  DEGRADED: DEGRADED means that the component is ready, but operating in a
    degraded state.
  DEPROVISIONING: DEPROVISIONING means that deprovisioning is in progress.
r   r   r#   r,   r>   r@   rA   rC   r   r   Nr  r   r   r   r  r    s8    & #$HLFGOHNr   r  c                   (    \ rS rSrSrSrSrSrSrSr	g)	(ControlPlaneRevision.TypeValueValuesEnumi  a  Type of the control plane revision.

Values:
  CONTROL_PLANE_REVISION_TYPE_UNSPECIFIED: Unspecified.
  UNMANAGED: User-installed in-cluster control plane revision.
  MANAGED_SERVICE: Google-managed service running outside the cluster.
    Note: Google-managed control planes are independent per-cluster,
    regardless of whether the revision name is the same or not.
  MANAGED_LOCAL: Google-managed local control plane revision.
r   r   r#   r,   r   N)
r   r   r   r   r   'CONTROL_PLANE_REVISION_TYPE_UNSPECIFIED	UNMANAGEDMANAGED_SERVICEMANAGED_LOCALr   r   r   r   TypeValueValuesEnumr    s    	 /0+IOMr   r  r   r  r#   Tr!   r,   r>   r@   rA   rC   r   N)r   r   r   r   r   r   r2   r  r  r  r6   channelr   r"  r%   ownerrevisionr  typerz   r   r   r   r   r  r    s    0y~~ "Y^^ <INN    8!<'""?AE'



"%""1%(


4a
8%			2A	6$!!!$'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
)CounterOptionsi  a  Increment a streamz counter with the specified metric and field names.
Metric names should start with a '/', generally be lowercase-only, and end
in "_count". Field names should not contain an initial slash. The actual
exported metric names will have "/iam/policy" prepended. Field names
correspond to IAM request parameters and field values are their respective
values. Supported field names: - "authority", which is "[token]" if
IAMContext.token is present, otherwise the value of
IAMContext.authority_selector if present, and otherwise a representation of
IAMContext.principal; or - "iam_principal", a representation of
IAMContext.principal even if a token or authority selector is present; or -
"" (empty string), resulting in a counter with no fields. Examples: counter
{ metric: "/debug_access_count" field: "iam_principal" } ==> increment
counter /iam/policy/debug_access_count {iam_principal=[value of
IAMContext.principal]}

Fields:
  customFields: Custom fields.
  field: The field value to attribute.
  metric: The metric to update.
CustomFieldr   Tr!   r#   r,   r   N)r   r   r   r   r   r   r   customFieldsr%   fieldmetricr   r   r   r   r  r    s=    * ''q4H,



"%  #&r   r  c                       \ rS rSrSr\R                  " S5      r\R                  " SS5      r	\R                  " S5      r
\R                  " S5      rSrg	)
CreateReferenceRequesti,  a  The CreateReferenceRequest request.

Fields:
  parent: Required. The parent resource name (target_resource of this
    reference). For example: `//targetservice.googleapis.com/projects/{my-
    project}/locations/{location}/instances/{my-instance}`.
  reference: Required. The reference to be created.
  referenceId: The unique id of this resource. Must be unique within a scope
    of a target resource, but does not have to be globally unique. Reference
    ID is part of resource name of the reference. Resource name is generated
    in the following way: {parent}/references/{reference_id}. Reference ID
    field is currently required but id auto generation might be added in the
    future. It can be any arbitrary string, either GUID or any other string,
    however CLHs can use preprocess callbacks to perform a custom
    validation.
  requestId: Optional. Request ID is an idempotency ID of the request. It
    must be a valid UUID. Zero UUID (00000000-0000-0000-0000-000000000000)
    is not supported.
r   	Referencer#   r,   r>   r   N)r   r   r   r   r   r   r%   parentr   	referencereferenceId	requestIdr   r   r   r   r  r  ,  sK    (   #&$$[!4)%%a(+##A&)r   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)r  iG  aL  Custom fields. These can be used to create a counter with arbitrary
field/value pairs. See: go/rpcsp-custom-fields.

Fields:
  name: Name is the field name.
  value: Value is the field value. It is important that in contrast to the
    CounterOptions.field, the value here is a constant that is not derived
    from the IAMContext.
r   r#   r   N)
r   r   r   r   r   r   r%   rG   r   r   r   r   r   r  r  G  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Srg)	DataAccessOptionsiV  zWrite a Data Access (Gin) log

Enums:
  LogModeValueValuesEnum:

Fields:
  isDirectAuth: Indicates that access was granted by a regular grant policy
  logMode: A LogModeValueValuesEnum attribute.
c                        \ rS rSrSrSrSrSrg)(DataAccessOptions.LogModeValueValuesEnumia  a  LogModeValueValuesEnum enum type.

Values:
  LOG_MODE_UNSPECIFIED: Client is not required to write a partial Gin log
    immediately after the authorization check. If client chooses to write
    one and it fails, client may either fail open (allow the operation to
    continue) or fail closed (handle as a DENY outcome).
  LOG_FAIL_CLOSED: The application's operation in the context of which
    this authorization check is being made may only be performed if it is
    successfully logged to Gin. For instance, the authorization library
    may satisfy this obligation by emitting a partial log entry at
    authorization check time and only returning ALLOW to the application
    if it succeeds. If a matching Rule has this directive, but the client
    has not indicated that it will honor such requirements, then the IAM
    check will result in authorization failure by setting
    CheckPolicyResponse.success=false.
r   r   r   N)r   r   r   r   r   LOG_MODE_UNSPECIFIEDLOG_FAIL_CLOSEDr   r   r   r   LogModeValueValuesEnumr  a  s    " Or   r  r   r#   r   N)r   r   r   r   r   r   r2   r  r4   isDirectAuthr6   logModer   r   r   r   r  r  V  s<    y~~ * ''*, 8!<'r   r  c                       \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	\R                  " SS	5      rS
rg)DataPlaneManagementiz  zStatus of data plane management. Only reported per-member.

Enums:
  StateValueValuesEnum: Lifecycle status of data plane management.

Fields:
  details: Explanation of the status.
  state: Lifecycle status of data plane management.
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g)(DataPlaneManagement.StateValueValuesEnumi  a^  Lifecycle status of data plane management.

Values:
  LIFECYCLE_STATE_UNSPECIFIED: Unspecified
  DISABLED: DISABLED means that the component is not enabled.
  FAILED_PRECONDITION: FAILED_PRECONDITION means that provisioning cannot
    proceed because of some characteristic of the member cluster.
  PROVISIONING: PROVISIONING means that provisioning is in progress.
  ACTIVE: ACTIVE means that the component is ready for use.
  STALLED: STALLED means that provisioning could not be done.
  NEEDS_ATTENTION: NEEDS_ATTENTION means that the component is ready, but
    some user intervention is required. (For example that the user should
    migrate workloads to a new control plane revision.)
  DEGRADED: DEGRADED means that the component is ready, but operating in a
    degraded state.
  DEPROVISIONING: DEPROVISIONING means that deprovisioning is in progress.
r   r   r#   r,   r>   r@   rA   rC   r   r   Nr  r   r   r   r  r    r  r   r  r  r   Tr!   r#   r   Nr   r   r   r   r   r   r2   r  r   r"  r6   r  r   r   r   r   r  r  z  s@    Y^^ 8 ""?AE'


4a
8%r   r  c                   <    \ rS rSrSr\R                  " S5      rSrg)DataplaneV2FeatureSpeci  zSpec for multi-cluster dataplane-v2 feature. This is required since
Feature proto requires a spec.

Fields:
  enableEncryption: Enable dataplane-v2 based encryption for multiple
    clusters.
r   r   N)	r   r   r   r   r   r   r4   enableEncryptionr   r   r   r   r  r    s     ++A.r   r  c                       \ rS rSrSrSrg)DataplaneV2FeatureStatei  ztAn empty state for multi-cluster dataplane-v2 feature. This is required
since FeatureStateDetails requires a state.
r   Nr   r   r   r   r  r    rY   r   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)DeleteReferenceRequesti  a  The DeleteReferenceRequest request.

Fields:
  name: Required. Full resource name of the reference, in the following
    format:
    `//{targer_service}/{target_resource}/references/{reference_id}`. For
    example: `//targetservice.googleapis.com/projects/{my-
    project}/locations/{location}/instances/{my-instance}/references/{xyz}`.
  requestId: Optional. Request ID is an idempotency ID of the request. It
    must be a valid UUID. Zero UUID (00000000-0000-0000-0000-000000000000)
    is not supported.
r   r#   r   N)
r   r   r   r   r   r   r%   rG   r  r   r   r   r   r  r    s)     
		q	!$##A&)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
)r<  i  a@  Configuration for a deployment override.

Fields:
  containers: Optional. The containers of the deployment resource to be
    overridden.
  deploymentName: Required. The name of the deployment resource to be
    overridden.
  deploymentNamespace: Required. The namespace of the deployment resource to
    be overridden.
r  r   Tr!   r#   r,   r   N)r   r   r   r   r   r   r   
containersr%   deploymentNamedeploymentNamespacer   r   r   r   r<  r<    s?    	 %%&91tL*((+.!--a0r   r<  c                       \ rS rSrSrSrg)Emptyi  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   Nr   r   r   r   r  r        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5      rSrg	)
ErrorResourcei  ad  Model for a config file in the git repo with an associated Sync error

Fields:
  resourceGvk: Group/version/kind of the resource that is causing an error
  resourceName: Metadata name of the resource that is causing an error
  resourceNamespace: Namespace of the resource that is causing an error
  sourcePath: Path in the git repo of the erroneous config
GroupVersionKindr   r#   r,   r>   r   N)r   r   r   r   r   r   r   resourceGvkr%   resourceNameresourceNamespace
sourcePathr   r   r   r   r  r    sM     &&'91=+&&q),++A.$$Q'*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\R                  " S5       " S S\R                  5      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\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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\R                  " S'S(5      r\R                  " S)S*5      r \R                  " S+S,5      r!\R                  " S-S.5      r"\R                  " S/S05      r#\R                   " S1S2S39r$\R                   " S45      r%\R                  " S5S65      r&S7r'g8)9Featurei  a  Feature represents the settings and status of any feature.

Messages:
  LabelsValue: Labels for this feature.

Fields:
  appdevexperienceFeatureSpec: The specification for App Dev Experience.
  authorizerFeatureSpec: The specification for the Authorizer Feature.
  cloudauditloggingFeatureSpec: The specification for Anthos Cloud Audit
    Logging.
  cloudbuildFeatureSpec: The specification for Cloud Build for Anthos.
  configmanagementFeatureSpec: The specification for Anthos Config
    Management.
  createTime: Output only. When the Feature was created.
  dataplanev2FeatureSpec: The specification for multi-cluster dataplane-v2.
  deleteTime: Output only. When the Feature was deleted.
  description: Description of the feature, limited to 63 characters.
  featureState: Output only. State of the Feature resource itself.
  fleetDefaultMemberConfig: FleetDefaultMemberConfig describes the default
    member configuration at the fleet level.
  fleetobservabilityFeatureSpec: The specification for FleetObservability
    feature.
  helloworldFeatureSpec: A Hello World feature for codelab examples and
    testing.
  identityserviceFeatureSpec: The specification for Anthos Identity Service.
  labels: Labels for this feature.
  meteringFeatureSpec: The specification for the Metering feature.
  multiclusteringressFeatureSpec: The specification for Ingress for Anthos.
  multiclusterservicediscoveryFeatureSpec: The specification for GKE Multi-
    Cluster Service Discovery.
  name: Output only. The full, unique name of this Feature resource in the
    format `projects/*/locations/global/features/*`.
  namespaceactuationFeatureSpec: The specification for Fleet Namespace
    Actuation.
  policycontrollerFeatureSpec: The specification for Policy Controller.
  rbacrolebindingactuationFeatureSpec: The specification for RBAC Role
    Binding Actuation.
  servicedirectoryFeatureSpec: The specification for Service Directory.
  servicemeshFeatureSpec: The specification for the Service Mesh Feature.
  unreachable: Output only. List of locations that could not be reached
    while fetching this feature.
  updateTime: Output only. When the Feature was last updated.
  workloadcertificateFeatureSpec: The specification for Workload
    Certificate.
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	)
Feature.LabelsValueiG  zLabels for this feature.

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)&Feature.LabelsValue.AdditionalPropertyiR  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%   r   r   r   r   r   r   r   r  R  )    
 !!!$c##A&er   r   r   Tr!   r   Nr   r   r   r   LabelsValuer  G  s2    	'Y.. 	' %112FTXYr   r  r	   r   rW   r#   r   r,   r   r>   r&  r@   rA   r  rC   r   r   FeatureStater   FleetDefaultMemberConfigr   FleetObservabilityFeatureSpecr   HelloWorldFeatureSpecr   IdentityServiceFeatureSpecr   r   MeteringFeatureSpecr
   MultiClusterIngressFeatureSpecr   'MultiClusterServiceDiscoveryFeatureSpecr   r   NamespaceActuationFeatureSpecr   PolicyControllerFeatureSpecr   #RBACRoleBindingActuationFeatureSpecr   ServiceDirectoryFeatureSpecr   ServiceMeshFeatureSpecr   r   Tr!   r   WorkloadCertificateFeatureSpecr   r   N)(r   r   r   r   r   r   r   r   r   r  r   appdevexperienceFeatureSpecauthorizerFeatureSpeccloudauditloggingFeatureSpeccloudbuildFeatureSpecconfigmanagementFeatureSpecr%   
createTimedataplanev2FeatureSpec
deleteTimer  featureStatefleetDefaultMemberConfigfleetobservabilityFeatureSpechelloworldFeatureSpecidentityserviceFeatureSpeclabelsmeteringFeatureSpecmulticlusteringressFeatureSpec'multiclusterservicediscoveryFeatureSpecrG   namespaceactuationFeatureSpecpolicycontrollerFeatureSpec#rbacrolebindingactuationFeatureSpecservicedirectoryFeatureSpecservicemeshFeatureSpecunreachable
updateTimeworkloadcertificateFeatureSpecr   r   r   r   r	  r	    sI   ,\ !!"89ZI%% Z :Z. !* 6 67TVW X#001H!L!*!7!78VXY!Z#001H!L ) 6 67TVW X$$Q'*$112JAN$$Q'*%%a(+'';,&334NPRS"+"8"89XZ\"]#001H"M(556RTVW!!-4&!../DbI#,#9#9:Z\^#_ ,5,B,BClnp,q)			r	"$"+"8"89XZ\"] ) 6 67TVX Y(1(>(>?dfh(i% ) 6 67TVX Y$112JBO%%b48+$$R(*#,#9#9:Z\^#_ r   r	  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)FeatureErrori|  zAll error details of the fleet observability feature.

Fields:
  code: The code of the error.
  description: A human-readable description of the current status.
r   r#   r   N)
r   r   r   r   r   r   r%   r!  r  r   r   r   r   r:  r:  |  s)     
		q	!$%%a(+r   r:  c                   Z   \ rS rSrSr " S S\R                  5      r\R                  " S5       " S S\R                  5      5       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\R                   " S5      r\R                  " S	S5      r\R(                  " S\R*                  R,                  S9r\R                   " S5      r\R(                  " S5      r\R4                  " SS5      rSrg)FeatureSamplei  a  Represents message used in feature e2e create/mutate testing.

Enums:
  ThirdValueValuesEnum:

Messages:
  FifthValue: A FifthValue object.
  NinthValue: Map field.

Fields:
  eighth: Repeated field.
  fifth: A FifthValue attribute.
  first: Singular scaler field.
  fourth: Singular Message fields.
  ninth: Map field.
  second: Singular scaler field.
  seventh: A string attribute.
  sixth: A string attribute.
  third: A ThirdValueValuesEnum attribute.
c                   $    \ rS rSrSrSrSrSrSrg)"FeatureSample.ThirdValueValuesEnumi  zThirdValueValuesEnum enum type.

Values:
  BAR_UNSPECIFIED: <no description>
  FIRST: <no description>
  SECOND: <no description>
r   r   r#   r   N)	r   r   r   r   r   BAR_UNSPECIFIEDFIRSTSECONDr   r   r   r   ThirdValueValuesEnumr>    s     OEFr   rB  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	)
FeatureSample.FifthValuei  zA FifthValue object.

Messages:
  AdditionalProperty: An additional property for a FifthValue 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)+FeatureSample.FifthValue.AdditionalPropertyi  zAn additional property for a FifthValue object.

Fields:
  key: Name of the additional property.
  value: A extra_types.JsonValue attribute.
r   extra_types.JsonValuer#   r   Nr   r   r   r   r   rF    ,    
 !!!$c$$%<a@er   r   r   Tr!   r   Nr   r   r   r   
FifthValuerD    4    	AY.. 	A %112FTXYr   rI  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
FeatureSample.NinthValuei  zMap field.

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

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

Fields:
  key: Name of the additional property.
  value: A FooBar attribute.
r   FooBarr#   r   Nr   r   r   r   r   rN    s+    
 !!!$c$$Xq1er   r   r   Tr!   r   Nr   r   r   r   
NinthValuerL    s2    	2Y.. 	2 %112FTXYr   rP  rO  r   Tr!   r#   r,   r>   r@   rA   r  rC   r   r   r   N)r   r   r   r   r   r   r2   rB  r   r   r   rI  rP  r   eighthfifthr%   firstfourthninthr  r  r  secondseventhsixthr6   thirdr   r   r   r   r<  r<    s"   *
Y^^ 
 !!"89Z9$$ Z :Z0 !!"89Z9$$ Z :Z. !!(A=&

 
 q
1%



"%  #&

 
 q
1%!!!Y->->-D-DE&!!!$'

 
 
#%


4a
8%r   r<  c                   ,   \ rS rSrSr " S S\R                  5      r\R                  " S5       " S S\R                  5      5       r\R                  " SS	5      r\R                  " SS
5      r\R                  " S5      r\R"                  " SS5      rSrg)r  i  a  FeatureState describes the state of a Feature resource.

Enums:
  LifecycleStateValueValuesEnum: The current state of the Feature resource.

Messages:
  DetailsByMembershipValue: FeatureState for each Membership. Keys are the
    fully-qualified Membership name in the format
    `projects/{NUMBER}/locations/*/memberships/*`.

Fields:
  details: Aggregate status message of the feature.
  detailsByMembership: FeatureState for each Membership. Keys are the fully-
    qualified Membership name in the format
    `projects/{NUMBER}/locations/*/memberships/*`.
  hasResources: Whether this Feature has outstanding resources that need to
    be cleaned up before it can be disabled.
  lifecycleState: The current state of the Feature resource.
c                   0    \ rS rSrSrSrSrSrSrSr	Sr
S	rg
)*FeatureState.LifecycleStateValueValuesEnumi  aW  The current state of the Feature resource.

Values:
  LIFECYCLE_STATE_UNSPECIFIED: State is unknown or not set.
  ENABLING: The Feature is being enabled.
  ENABLED: The Feature is active.
  DISABLING: The Feature is being disabled.
  UPDATING: The Feature is being updated.
  SERVICE_UPDATING: The Feature is being updated by the Hub Service.
r   r   r#   r,   r>   r@   r   N)r   r   r   r   r   r  ENABLINGENABLED	DISABLINGr  SERVICE_UPDATINGr   r   r   r   LifecycleStateValueValuesEnumr\    s)    	 #$HGIHr   ra  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	)
%FeatureState.DetailsByMembershipValuei  aK  FeatureState for each Membership. Keys are the fully-qualified
Membership name in the format
`projects/{NUMBER}/locations/*/memberships/*`.

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

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

Fields:
  key: Name of the additional property.
  value: A FeatureStateDetails attribute.
r   FeatureStateDetailsr#   r   Nr   r   r   r   r   re    s,    
 !!!$c$$%:A>er   r   r   Tr!   r   Nr   r   r   r   DetailsByMembershipValuerc    s2    	?Y.. 	? %112FTXYr   rg  rf  r   r#   r,   r>   r   N)r   r   r   r   r   r   r2   ra  r   r   r   rg  r   r"  detailsByMembershipr4   hasResourcesr6   lifecycleStater   r   r   r   r  r    s    (inn $ !!"89Z!2!2 Z :Z6 ""#8!<'!../I1M''*,&&'FJ.r   r  c                   6   \ 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S5      r\R                  " SS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\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'5      r\R                  " S(S)5      rS*rg+),rf  i/  a  FeatureStateDetails is a semi-structured status message for a
declarative resource in the API.

Enums:
  CodeValueValuesEnum: The code describes, at a high level, if the Feature
    is operating correctly. Non-`OK` codes should have details in the
    `description` describing what actions (if any) need to be taken to
    return the Feature to `OK`.

Fields:
  appdevexperienceFeatureState: State for the AppDevExperience Feature.
  authorizerFeatureState: State for the Authorizer Feature.
  cloudauditloggingFeatureState: The state of the Anthos Cloud Audit Logging
    feature.
  code: The code describes, at a high level, if the Feature is operating
    correctly. Non-`OK` codes should have details in the `description`
    describing what actions (if any) need to be taken to return the Feature
    to `OK`.
  configmanagementFeatureState: State for the Config Management Feature.
  dataplanev2FeatureState: State for multi-cluster dataplane-v2 feature.
  description: Human readable description of the issue.
  fleetobservabilityFeatureState: State for the FleetObservability Feature.
  helloworldFeatureState: State for the Hello World Feature.
  identityserviceFeatureState: State for the AIS Feature.
  meteringFeatureState: State for the Metering Feature.
  multiclusteringressFeatureState: State for the Ingress for Anthos Feature.
  multiclusterservicediscoveryFeatureState: State for the Multi-cluster
    Service Discovery Feature.
  namespaceactuationFeatureState: State for Fleet Namespace Actuation.
  policycontrollerFeatureState: State for the Policy Controller Feature.
  rbacrolebindingactuationFeatureState: State for RBAC Role Binding
    Actuation.
  servicedirectoryFeatureState: State for the Service Directory Feature.
  servicemeshFeatureState: State for the Service Mesh Feature.
  updateTime: The last update time of this status by the controllers
  workloadcertificateFeatureState: State for the Workload Certificate
    Feature
c                   (    \ rS rSrSrSrSrSrSrSr	g)	'FeatureStateDetails.CodeValueValuesEnumiW  a  The code describes, at a high level, if the Feature is operating
correctly. Non-`OK` codes should have details in the `description`
describing what actions (if any) need to be taken to return the Feature to
`OK`.

Values:
  CODE_UNSPECIFIED: Not set.
  OK: No error.
  FAILED: The Feature has encountered an issue that blocks all, or a
    significant portion, of its normal operation. See the `description`
    for more details.
  WARNING: The Feature is in a state, or has encountered an issue, that
    impacts its normal operation. This state may or may not require
    intervention to resolve, see the `description` for more details.
r   r   r#   r,   r   N)
r   r   r   r   r   r   OKFAILEDr  r   r   r   r   r  rm  W  s     	
BFGr   r  r   r   r[   r#   r   r,   r>   r-  r@   r  rA   rC   FleetObservabilityFeatureStater   HelloWorldFeatureStater   IdentityServiceFeatureStater   MeteringFeatureStater   MultiClusterIngressFeatureStater   (MultiClusterServiceDiscoveryFeatureStater   NamespaceActuationFeatureStater   PolicyControllerFeatureStater   $RBACRoleBindingActuationFeatureStater
   ServiceDirectoryFeatureStater   ServiceMeshFeatureStater   r   WorkloadCertificateFeatureStater   r   N) r   r   r   r   r   r   r2   r  r   appdevexperienceFeatureStateauthorizerFeatureStatecloudauditloggingFeatureStater6   r!  configmanagementFeatureStatedataplanev2FeatureStater%   r  fleetobservabilityFeatureStatehelloworldFeatureStateidentityserviceFeatureStatemeteringFeatureStatemulticlusteringressFeatureState(multiclusterservicediscoveryFeatureStatenamespaceactuationFeatureStatepolicycontrollerFeatureState$rbacrolebindingactuationFeatureStateservicedirectoryFeatureStateservicemeshFeatureStater7  workloadcertificateFeatureStater   r   r   r   rf  rf  /  s   %NINN * "+!7!78VXY!Z$112JAN"+"8"89XZ["\			2A	6$!*!7!78VXY!Z%223LaP%%a(+#,#9#9:Z\]#^ $112JAN ) 6 67TVX Y"//0FK$-$:$:;\^`$a!-6-C-CDnpr-s*#,#9#9:Z\^#_ !*!7!78VXZ![)2)?)?@fhj)k&!*!7!78VXZ![%223LbQ$$R(*$-$:$:;\^`$a!r   rf  c                   d    \ rS rSrSr\R                  " SS5      r\R                  " SS5      rSr	g)	r  i  zFleetDefaultMemberConfig contains default configuration information for
memberships of a fleet.

Fields:
  identityService: Spec for IdentityService.
  serviceMesh: Spec for ServiceMesh.
MemberConfigr   ServiceMeshMembershipSpecr#   r   N)
r   r   r   r   r   r   r   identityServiceserviceMeshr   r   r   r   r  r    s.     **>1=/&&'BAF+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)"FleetObservabilityBaseFeatureStatei  a3  Base state for fleet observability feature.

Enums:
  CodeValueValuesEnum: The high-level, machine-readable status of this
    Feature.

Fields:
  code: The high-level, machine-readable status of this Feature.
  errors: Errors after reconciling the monitoring and logging feature if the
    code is not OK.
c                   $    \ rS rSrSrSrSrSrSrg)6FleetObservabilityBaseFeatureState.CodeValueValuesEnumi  ay  The high-level, machine-readable status of this Feature.

Values:
  CODE_UNSPECIFIED: Unknown or not set.
  OK: The Feature is operating normally.
  ERROR: The Feature is encountering errors in the reconciliation. The
    Feature may need intervention to return to normal operation. See the
    description and any associated Feature-specific details for more
    information.
r   r   r#   r   N)	r   r   r   r   r   r   rn  ru   r   r   r   r   r  r    s    	 	
BEr   r  r   r:  r#   Tr!   r   N)r   r   r   r   r   r   r2   r  r6   r!  r   r  r   r   r   r   r  r    s@    
INN  
		2A	6$!!.!dC&r   r  c                   >    \ rS rSrSr\R                  " SS5      rSrg)r  i  a	  Spec for FleetObservability feature. This is required since Feature
proto requires a spec.

Fields:
  loggingConfig: Specified if fleet logging feature is enabled for the
    entire fleet. If UNSPECIFIED, fleet logging feature is disabled for the
    entire fleet.
LoggingConfigr   r   N)	r   r   r   r   r   r   r   loggingConfigr   r   r   r   r  r    s     ((!<-r   r  c                   d    \ rS rSrSr\R                  " SS5      r\R                  " SS5      rSr	g)	rp  i  zAn empty state for FleetObservability feature. This is required since
FeatureStateDetails requires a state.

Fields:
  logging: The feature state of fleet logging.
  monitoring: The feature state of fleet monitoring.
FleetObservabilityLoggingStater   !FleetObservabilityMonitoringStater#   r   N)
r   r   r   r   r   r   r   logging
monitoringr   r   r   r   rp  rp    s/     ""#CQG'%%&I1M*r   rp  c                   d    \ rS rSrSr\R                  " SS5      r\R                  " SS5      rSr	g)r  i  zFeature state for logging feature.

Fields:
  defaultLog: The base feature state of fleet default log.
  scopeLog: The base feature state of fleet scope log.
r  r   r#   r   N)
r   r   r   r   r   r   r   
defaultLogscopeLogr   r   r   r   r  r    s/     %%&JAN*##$H!L(r   r  c                   >    \ rS rSrSr\R                  " SS5      rSrg)r  i  zlFeature state for monitoring feature.

Fields:
  state: The base feature state of fleet monitoring feature.
r  r   r   N)	r   r   r   r   r   r   r   r  r   r   r   r   r  r    s     
 
 !Eq
I%r   r  c                       \ rS rSrSr\R                  " S5      r\R                  " S\R                  R                  S9rSrg)rO  i  zUNested Message.

Fields:
  first: A string attribute.
  second: A integer attribute.
r   r#   r  r   N)r   r   r   r   r   r   r%   rS  r  r  r  rV  r   r   r   r   rO  rO    s7     


"%!!!Y->->-D-DE&r   rO  c                      \ rS rSrSr " S S\R                  5      r " S S\R                  5      r " S S\R                  5      r	\R                  " SS	5      r\R                  " SS
5      r\R                  " SS5      rSrg)GatekeeperDeploymentStatei  a  State of Policy Controller installation.

Enums:
  GatekeeperAuditValueValuesEnum: Status of gatekeeper-audit deployment.
  GatekeeperControllerManagerStateValueValuesEnum: Status of gatekeeper-
    controller-manager pod.
  GatekeeperMutationValueValuesEnum: Status of the pod serving the mutation
    webhook.

Fields:
  gatekeeperAudit: Status of gatekeeper-audit deployment.
  gatekeeperControllerManagerState: Status of gatekeeper-controller-manager
    pod.
  gatekeeperMutation: Status of the pod serving the mutation webhook.
c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
8GatekeeperDeploymentState.GatekeeperAuditValueValuesEnumi  a?  Status of gatekeeper-audit deployment.

Values:
  DEPLOYMENT_STATE_UNSPECIFIED: Deployment's state cannot be determined
  NOT_INSTALLED: Deployment is not installed
  INSTALLED: Deployment is installed
  ERROR: Deployment was attempted to be installed, but has errors
  PENDING: Deployment is installing or terminating
r   r   r#   r,   r>   r   Nrq   r   r   r   GatekeeperAuditValueValuesEnumr    rx   r   r  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
IGatekeeperDeploymentState.GatekeeperControllerManagerStateValueValuesEnumi  aE  Status of gatekeeper-controller-manager pod.

Values:
  DEPLOYMENT_STATE_UNSPECIFIED: Deployment's state cannot be determined
  NOT_INSTALLED: Deployment is not installed
  INSTALLED: Deployment is installed
  ERROR: Deployment was attempted to be installed, but has errors
  PENDING: Deployment is installing or terminating
r   r   r#   r,   r>   r   Nrq   r   r   r   /GatekeeperControllerManagerStateValueValuesEnumr    rx   r   r  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
;GatekeeperDeploymentState.GatekeeperMutationValueValuesEnumi  aH  Status of the pod serving the mutation webhook.

Values:
  DEPLOYMENT_STATE_UNSPECIFIED: Deployment's state cannot be determined
  NOT_INSTALLED: Deployment is not installed
  INSTALLED: Deployment is installed
  ERROR: Deployment was attempted to be installed, but has errors
  PENDING: Deployment is installing or terminating
r   r   r#   r,   r>   r   Nrq   r   r   r   !GatekeeperMutationValueValuesEnumr    rx   r   r  r   r#   r,   r   N)r   r   r   r   r   r   r2   r  r  r  r6   gatekeeperAudit gatekeeperControllerManagerStategatekeeperMutationr   r   r   r   r  r    sv     y~~  	  )..   ''(H!L/%.%8%89jlm%n" **+NPQRr   r  c                   <    \ rS rSrSr\R                  " S5      rSrg)GetReferenceRequesti1  aP  The GetReferenceRequest request.

Fields:
  name: Required. Full resource name of the reference, in the following
    format:
    `//{target_service}/{target_resource}/references/{reference_id}`. For
    example: `//targetservice.googleapis.com/projects/{my-
    project}/locations/{location}/instances/{my-instance}/references/{xyz}`.
r   r   N	r   r   r   r   r   r   r%   rG   r   r   r   r   r  r  1  s     
		q	!$r   r  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?  a  Git repo configuration for a single cluster.

Fields:
  gcpServiceAccountEmail: The Google Cloud Service Account Email used for
    auth when secret_type is gcpServiceAccount.
  httpsProxy: URL for the HTTPS proxy to be used when communicating with the
    Git repo.
  policyDir: The path within the Git repository that represents the top
    level of the repo to sync. Default: the root directory of the
    repository.
  secretType: Required. Type of secret configured for access to the Git
    repo.
  syncBranch: The branch of the repository to sync from. Default: master.
  syncRepo: The URL of the Git repository to use as the source of truth.
  syncRev: Git revision (tag or hash) to check out. Default HEAD.
  syncWaitSecs: Period in seconds between consecutive syncs. Default: 15.
r   r#   r,   r>   r@   rA   rC   r   r   N)r   r   r   r   r   r   r%   gcpServiceAccountEmail
httpsProxy	policyDir
secretType
syncBranchsyncReposyncRevr  syncWaitSecsr   r   r   r   r=  r=  ?  s    $ %003$$Q'*##A&)$$Q'*$$Q'*""1%(!!!$'''*,r   r=  c                       \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " SSS9rSrg	)
2GkehubProjectsLocationsFeaturesGetIamPolicyRequesti\  a>  A GkehubProjectsLocationsFeaturesGetIamPolicyRequest object.

Fields:
  options_requestedPolicyVersion: Optional. The maximum policy version that
    will be used to format the policy. Valid values are 0, 1, and 3.
    Requests specifying an invalid value will be rejected. Requests for
    policies with any conditional role bindings must specify version 3.
    Policies with no conditional role bindings may specify any valid value
    or leave the field unset. The policy in the response might use the
    policy version that you specified, or it might use a lower policy
    version. For example, if you specify version 3, but the policy has no
    conditional role bindings, the response uses version 1. To learn which
    resources support conditions in their IAM policies, see the [IAM
    documentation](https://cloud.google.com/iam/help/conditions/resource-
    policies).
  resource: REQUIRED: The resource for which the policy is being requested.
    See [Resource
    names](https://cloud.google.com/apis/design/resource_names) for the
    appropriate value for this field.
r   r  r#   Trequiredr   N)r   r   r   r   r   r   r  r  r  options_requestedPolicyVersionr%   resourcer   r   r   r   r  r  \  s:    * $-#9#9!YEVEVE\E\#] ""1t4(r   r  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
2GkehubProjectsLocationsFeaturesSetIamPolicyRequestiv  an  A GkehubProjectsLocationsFeaturesSetIamPolicyRequest object.

Fields:
  resource: REQUIRED: The resource for which the policy is being specified.
    See [Resource
    names](https://cloud.google.com/apis/design/resource_names) for the
    appropriate value for this field.
  setIamPolicyRequest: A SetIamPolicyRequest resource to be passed as the
    request body.
r   Tr  SetIamPolicyRequestr#   r   N)r   r   r   r   r   r   r%   r  r   setIamPolicyRequestr   r   r   r   r  r  v  s/    	 ""1t4(!../DaHr   r  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
8GkehubProjectsLocationsFeaturesTestIamPermissionsRequesti  a  A GkehubProjectsLocationsFeaturesTestIamPermissionsRequest object.

Fields:
  resource: REQUIRED: The resource for which the policy detail is being
    requested. See [Resource
    names](https://cloud.google.com/apis/design/resource_names) for the
    appropriate value for this field.
  testIamPermissionsRequest: A TestIamPermissionsRequest resource to be
    passed as the request body.
r   Tr  TestIamPermissionsRequestr#   r   N)r   r   r   r   r   r   r%   r  r   testIamPermissionsRequestr   r   r   r   r  r    s0    	 ""1t4('445PRSTr   r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)!GkehubProjectsLocationsGetRequesti  z]A GkehubProjectsLocationsGetRequest object.

Fields:
  name: Resource name for the location.
r   Tr  r   Nr  r   r   r   r  r         
		q4	0$r   r  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
)2GkehubProjectsLocationsGlobalFeaturesCreateRequesti  aH  A GkehubProjectsLocationsGlobalFeaturesCreateRequest object.

Fields:
  feature: A Feature resource to be passed as the request body.
  featureId: The ID of the feature to create.
  parent: Required. The parent (project and location) where the Feature will
    be created. Specified in the format `projects/*/locations/global`.
r	  r   r#   r,   Tr  r   N)r   r   r   r   r   r   r   featurer%   	featureIdr  r   r   r   r   r  r    s=     ""9a0'##A&)  T2&r   r  c                   ^    \ rS rSrSr\R                  " S5      r\R                  " SSS9r	Sr
g)	2GkehubProjectsLocationsGlobalFeaturesDeleteRequesti  a  A GkehubProjectsLocationsGlobalFeaturesDeleteRequest object.

Fields:
  force: If set to true, the delete will ignore any outstanding resources
    for this Feature (that is, `FeatureState.has_resources` is set to true).
    These resources will NOT be cleaned up or modified in any way.
  name: Required. The Feature resource name in the format
    `projects/*/locations/global/features/*`.
r   r#   Tr  r   N)r   r   r   r   r   r   r4   forcer%   rG   r   r   r   r   r  r    s+     
 
 
#%			q4	0$r   r  c                   ^    \ rS rSrSr\R                  " SSS9r\R                  " S5      r	Sr
g)	/GkehubProjectsLocationsGlobalFeaturesGetRequesti  a  A GkehubProjectsLocationsGlobalFeaturesGetRequest object.

Fields:
  name: Required. The Feature resource name in the format
    `projects/*/locations/global/features/*`
  returnPartialSuccess: Optional. If set to true, the response will return
    partial results when some regions are unreachable and the unreachable
    field in Feature proto will be populated. If set to false, the request
    will fail when some regions are unreachable.
r   Tr  r#   r   N)r   r   r   r   r   r   r%   rG   r4   returnPartialSuccessr   r   r   r   r  r    s,    	 
		q4	0$"//2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\R                  " S5      rSrg)0GkehubProjectsLocationsGlobalFeaturesListRequesti  a  A GkehubProjectsLocationsGlobalFeaturesListRequest object.

Fields:
  filter: Lists Features that match the filter expression, following the
    syntax outlined in https://google.aip.dev/160. Examples: - Feature with
    the name "servicemesh" in project "foo-proj": name = "projects/foo-
    proj/locations/global/features/servicemesh" - Service Mesh Feature with
    `mtls` enabled: servicemesh_feature_spec.mtls = true - Features that
    have a label called `foo`: labels.foo:* - Features that have a label
    called `foo` whose value is `bar`: labels.foo = bar
  orderBy: One or more fields to compare and use to sort the output. See
    https://google.aip.dev/132#ordering.
  pageSize: When requesting a 'page' of resources, `page_size` specifies
    number of resources to return. If unspecified or set to 0, all resources
    will be returned.
  pageToken: Token returned by previous call to `ListFeatures` which
    specifies the position in the list from where to continue listing the
    resources.
  parent: Required. The parent (project and location) where the Features
    will be listed. Specified in the format `projects/*/locations/global`.
  returnPartialSuccess: Optional. If set to true, the response will return
    partial results when some regions are unreachable and the unreachable
    field in Feature proto will be populated. If set to false, the request
    will fail when some regions are unreachable.
r   r#   r,   r  r>   r@   Tr  rA   r   N)r   r   r   r   r   r   r%   filterorderByr  r  r  pageSize	pageTokenr  r4   r  r   r   r   r   r  r    sz    4   #&!!!$'##Ay/@/@/F/FG(##A&)  T2&"//2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
)1GkehubProjectsLocationsGlobalFeaturesPatchRequesti  a  A GkehubProjectsLocationsGlobalFeaturesPatchRequest object.

Fields:
  feature: A Feature resource to be passed as the request body.
  name: Required. The Feature resource name in the format
    `projects/*/locations/global/features/*`.
  updateMask: Mask of fields to update.
r	  r   r#   Tr  r,   r   N)r   r   r   r   r   r   r   r  r%   rG   
updateMaskr   r   r   r   r  r    s=     ""9a0'			q4	0$$$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SS	9r\R                  " S
\R                  R                  S9r\R                  " S5      rSrg)"GkehubProjectsLocationsListRequesti 	  ae  A GkehubProjectsLocationsListRequest object.

Fields:
  extraLocationTypes: Optional. Do not use this field. It is unsupported and
    is ignored unless explicitly documented otherwise. This is primarily for
    internal usage.
  filter: A filter to narrow down results to a preferred subset. The
    filtering language accepts strings like `"displayName=tokyo"`, and is
    documented in more detail in [AIP-160](https://google.aip.dev/160).
  includeUnrevealedLocations: If true, the returned list will include
    locations which are not yet revealed.
  name: The resource that owns the locations collection, if applicable.
  pageSize: The maximum number of results to return. If not set, the service
    selects a default.
  pageToken: A page token received from the `next_page_token` field in the
    response. Send that page token to receive the subsequent page.
r   Tr!   r#   r,   r>   r  r@   r  rA   r   N)r   r   r   r   r   r   r%   extraLocationTypesr  r4   includeUnrevealedLocationsrG   r  r  r  r  r  r   r   r   r   r  r   	  s}    $ !,,Q>  #&(55a8			q4	0$##Ay/@/@/F/FG(##A&)r   r  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
.GkehubProjectsLocationsOperationsCancelRequesti	  zA GkehubProjectsLocationsOperationsCancelRequest object.

Fields:
  cancelOperationRequest: A CancelOperationRequest resource to be passed as
    the request body.
  name: The name of the operation resource to be cancelled.
r   r   r#   Tr  r   N)r   r   r   r   r   r   r   cancelOperationRequestr%   rG   r   r   r   r   r  r  	  s/     %112JAN			q4	0$r   r  c                   :    \ rS rSrSr\R                  " SSS9rSrg).GkehubProjectsLocationsOperationsDeleteRequesti(	  z|A GkehubProjectsLocationsOperationsDeleteRequest object.

Fields:
  name: The name of the operation resource to be deleted.
r   Tr  r   Nr  r   r   r   r  r  (	  r  r   r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)+GkehubProjectsLocationsOperationsGetRequesti2	  zkA GkehubProjectsLocationsOperationsGetRequest object.

Fields:
  name: The name of the operation resource.
r   Tr  r   Nr  r   r   r   r  r  2	  r  r   r  c                       \ rS rSrS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Srg),GkehubProjectsLocationsOperationsListRequesti<	  a  A GkehubProjectsLocationsOperationsListRequest object.

Fields:
  filter: The standard list filter.
  name: The name of the operation's parent resource.
  pageSize: The standard list page size.
  pageToken: The standard list page token.
  returnPartialSuccess: When set to `true`, operations that are reachable
    are returned as normal, and those that are unreachable are returned in
    the [ListOperationsResponse.unreachable] field. This can only be `true`
    when reading across collections e.g. when `parent` is set to
    `"projects/example/locations/-"`. This field is not by default supported
    and will result in an `UNIMPLEMENTED` error if set unless explicitly
    documented otherwise in service or product specific documentation.
r   r#   Tr  r,   r  r>   r@   r   N)r   r   r   r   r   r   r%   r  rG   r  r  r  r  r  r4   r  r   r   r   r   r  r  <	  sj        #&			q4	0$##Ay/@/@/F/FG(##A&)"//2r   r  c                   <    \ rS rSrSr\R                  " S5      rSrg)r<   iT	  zConfiguration for the Google Plugin Auth flow.

Fields:
  disable: Disable automatic configuration of Google Plugin on supported
    platforms.
r   r   N)	r   r   r   r   r   r   r4   disabler   r   r   r   r<   r<   T	  s     ""1%'r   r<   c                   N   \ rS rSrSr " S S\R                  5      r " S S\R                  5      r " S S\R                  5      r	\R                  " SS	5      r\R                  " SS
5      r\R                  " S5      r\R                  " SS5      r\R                  " SSS9rSrg)GoogleIamV1Conditioni_	  ad  A condition to be met.

Enums:
  IamValueValuesEnum: Trusted attributes supplied by the IAM system.
  OpValueValuesEnum: An operator to apply the subject with.
  SysValueValuesEnum: Trusted attributes supplied by any service that owns
    resources and uses the IAM system for access control.

Fields:
  iam: Trusted attributes supplied by the IAM system.
  op: An operator to apply the subject with.
  svc: Trusted attributes discharged by the service.
  sys: Trusted attributes supplied by any service that owns resources and
    uses the IAM system for access control.
  values: The objects of the condition.
c                   8    \ 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)'GoogleIamV1Condition.IamValueValuesEnumiq	  a  Trusted attributes supplied by the IAM system.

Values:
  NO_ATTR: Default non-attribute.
  AUTHORITY: Either principal or (if present) authority selector.
  ATTRIBUTION: The principal (even if an authority selector is present),
    which must only be used for attribution, not authorization.
  SECURITY_REALM: Any of the security realms in the IAMContext
    (go/security-realms). When used with IN, the condition indicates "any
    of the request's realms match one of the given values; with NOT_IN,
    "none of the realms match any of the given values". Note that a value
    can be: - 'self:campus' (i.e., clients that are in the same campus) -
    'self:metro' (i.e., clients that are in the same metro) - 'self:cloud-
    region' (i.e., allow connections from clients that are in the same
    cloud region) - 'self:prod-region' (i.e., allow connections from
    clients that are in the same prod region) - 'guardians' (i.e., allow
    connections from its guardian realms. See go/security-realms-
    glossary#guardian for more information.) - 'cryto_core_guardians'
    (i.e., allow connections from its crypto core guardian realms. See
    go/security-realms-glossary#guardian for more information.) Crypto
    Core coverage is a super-set of Default coverage, containing
    information about coverage between higher tier data centers (e.g.,
    YAWNs). Most services should use Default coverage and only use Crypto
    Core coverage if the service is involved in greenfield turnup of new
    higher tier data centers (e.g., credential infrastructure, machine/job
    management systems, etc.). - 'self' [DEPRECATED] (i.e., allow
    connections from clients that are in the same security realm, which is
    currently but not guaranteed to be campus-sized) - a realm (e.g.,
    'campus-abc') - a realm group (e.g., 'realms-for-borg-cell-xx', see:
    go/realm-groups) A match is determined by a realm group membership
    check performed by a RealmAclRep object (go/realm-acl-howto). It is
    not permitted to grant access based on the *absence* of a realm, so
    realm conditions can only be used in a "positive" context (e.g.,
    ALLOW/IN or DENY/NOT_IN).
  APPROVER: An approver (distinct from the requester) that has authorized
    this request. When used with IN, the condition indicates that one of
    the approvers associated with the request matches the specified
    principal, or is a member of the specified group. Approvers can only
    grant additional access, and are thus only used in a strictly positive
    context (e.g. ALLOW/IN or DENY/NOT_IN).
  JUSTIFICATION_TYPE: What types of justifications have been supplied with
    this request. String values should match enum names from
    security.credentials.JustificationType, e.g. "MANUAL_STRING". It is
    not permitted to grant access based on the *absence* of a
    justification, so justification conditions can only be used in a
    "positive" context (e.g., ALLOW/IN or DENY/NOT_IN). Multiple
    justifications, e.g., a Buganizer ID and a manually-entered reason,
    are normal and supported.
  CREDENTIALS_TYPE: What type of credentials have been supplied with this
    request. String values should match enum names from
    security_loas_l2.CredentialsType - currently, only
    CREDS_TYPE_EMERGENCY is supported. It is not permitted to grant access
    based on the *absence* of a credentials type, so the conditions can
    only be used in a "positive" context (e.g., ALLOW/IN or DENY/NOT_IN).
  CREDS_ASSERTION: Properties of the credentials supplied with this
    request. See http://go/rpcsp-credential-assertions?polyglot=rpcsp-v1-0
    The conditions can only be used in a "positive" context (e.g.,
    ALLOW/IN or DENY/NOT_IN).
r   r   r#   r,   r>   r@   rA   rC   r   N)r   r   r   r   r   NO_ATTR	AUTHORITYATTRIBUTIONSECURITY_REALMAPPROVERJUSTIFICATION_TYPECREDENTIALS_TYPECREDS_ASSERTIONr   r   r   r   IamValueValuesEnumr  q	  s4    :v GIKNHOr   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
)&GoogleIamV1Condition.OpValueValuesEnumi	  a  An operator to apply the subject with.

Values:
  NO_OP: Default no-op.
  EQUALS: DEPRECATED. Use IN instead.
  NOT_EQUALS: DEPRECATED. Use NOT_IN instead.
  IN: The condition is true if the subject (or any element of it if it is
    a set) matches any of the supplied values.
  NOT_IN: The condition is true if the subject (or every element of it if
    it is a set) matches none of the supplied values.
  DISCHARGED: Subject is discharged
r   r   r#   r,   r>   r@   r   N)r   r   r   r   r   NO_OPEQUALS
NOT_EQUALSINNOT_IN
DISCHARGEDr   r   r   r   OpValueValuesEnumr  	  s'     EFJ	
BFJr   r  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
'GoogleIamV1Condition.SysValueValuesEnumi	  a  Trusted attributes supplied by any service that owns resources and
uses the IAM system for access control.

Values:
  NO_ATTR: Default non-attribute type
  REGION: Region of the resource
  SERVICE: Service name
  NAME: Resource name
  IP: IP address of the caller
r   r   r#   r,   r>   r   N)r   r   r   r   r   r  REGIONSERVICENAMEIPr   r   r   r   SysValueValuesEnumr  	  s"    	 GFGD	
Br   r  r   r#   r,   r>   r@   Tr!   r   N)r   r   r   r   r   r   r2   r  r  r  r6   iamopr%   svcsysvaluesr   r   r   r   r  r  _	  s    "C9>> CJ).. (9>> " 	0!4#.2"a #0!4#  T2&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)GoogleRpcStatusi	  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.
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	)
%GoogleRpcStatus.DetailsValueListEntryi	  A 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)8GoogleRpcStatus.DetailsValueListEntry.AdditionalPropertyi
  An additional property for a DetailsValueListEntry object.

Fields:
  key: Name of the additional property.
  value: A extra_types.JsonValue attribute.
r   rG  r#   r   Nr   r   r   r   r   r  
  rH  r   r   r   Tr!   r   Nr   r   r   r   DetailsValueListEntryr  	  4    		AY.. 	A %112FTXYr   r  r   r  r#   Tr!   r,   r   N)r   r   r   r   r   r   r   r   r   r  r  r  r  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\R                  " S5      r	Sr
g)GroupConfigi
  a  Contains the properties for locating and authenticating groups in the
directory.

Fields:
  baseDn: Required. The location of the subtree in the LDAP directory to
    search for group entries.
  filter: Optional. Optional filter to be used when searching for groups a
    user belongs to. This can be used to explicitly match only certain
    groups in order to reduce the amount of groups returned for each user.
    This defaults to "(objectClass=Group)".
  idAttribute: Optional. The identifying name of each group a user belongs
    to. For example, if this is set to "distinguishedName" then RBACs and
    other group expectations should be written as full DNs. This defaults to
    "distinguishedName".
r   r#   r,   r   N)r   r   r   r   r   r   r%   baseDnr  idAttributer   r   r   r   r  r  
  s9        #&  #&%%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)r  i+
  zsA Kubernetes object's GVK

Fields:
  group: Kubernetes Group
  kind: Kubernetes Kind
  version: Kubernetes Version
r   r#   r,   r   N)r   r   r   r   r   r   r%   groupkindrz   r   r   r   r   r  r  +
  s9     


"%			q	!$!!!$'r   r  c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)r  i9
  a  HelloWorldFeatureSpec contains the input for the HelloWorld feature.

Fields:
  customConfig: Custom config for the HelloWorld controller codelab. This
    should be a textpb string.
  featureSample: Message to hold fields to use in feature e2e create/mutate
    testing.
r   r<  r#   r   N)r   r   r   r   r   r   r%   customConfigr   featureSampler   r   r   r   r  r  9
  s+     &&q),((!<-r   r  c                       \ rS rSrSrSrg)rq  iG
  zdAn empty state for HelloWorld feature. This is required since
FeatureStateDetails requires a state.
r   Nr   r   r   r   rq  rq  G
  rY   r   rq  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S5      r	Sr
g)HierarchyControllerConfigiN
  a'  Configuration for Hierarchy Controller

Fields:
  enableHierarchicalResourceQuota: Whether hierarchical resource quota is
    enabled in this cluster.
  enablePodTreeLabels: Whether pod tree labels are enabled in this cluster.
  enabled: Whether Hierarchy Controller is enabled in this cluster.
r   r#   r,   r   N)r   r   r   r   r   r   r4   enableHierarchicalResourceQuotaenablePodTreeLabelsrj   r   r   r   r   r)  r)  N
  s;     %.$:$:1$=!!..q1""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
)"HierarchyControllerDeploymentStatei]
  a  Deployment state for Hierarchy Controller

Enums:
  ExtensionValueValuesEnum: The deployment state for Hierarchy Controller
    extension (e.g. v0.7.0-hc.1)
  HncValueValuesEnum: The deployment state for open source HNC (e.g.
    v0.7.0-hc.0)

Fields:
  extension: The deployment state for Hierarchy Controller extension (e.g.
    v0.7.0-hc.1)
  hnc: The deployment state for open source HNC (e.g. v0.7.0-hc.0)
c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
;HierarchyControllerDeploymentState.ExtensionValueValuesEnumil
  ac  The deployment state for Hierarchy Controller extension (e.g.
v0.7.0-hc.1)

Values:
  DEPLOYMENT_STATE_UNSPECIFIED: Deployment's state cannot be determined
  NOT_INSTALLED: Deployment is not installed
  INSTALLED: Deployment is installed
  ERROR: Deployment was attempted to be installed, but has errors
  PENDING: Deployment is installing or terminating
r   r   r#   r,   r>   r   Nrq   r   r   r   ExtensionValueValuesEnumr/  l
  s#    	 $% MIEGr   r0  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
5HierarchyControllerDeploymentState.HncValueValuesEnumi}
  aT  The deployment state for open source HNC (e.g. v0.7.0-hc.0)

Values:
  DEPLOYMENT_STATE_UNSPECIFIED: Deployment's state cannot be determined
  NOT_INSTALLED: Deployment is not installed
  INSTALLED: Deployment is installed
  ERROR: Deployment was attempted to be installed, but has errors
  PENDING: Deployment is installing or terminating
r   r   r#   r,   r>   r   Nrq   r   r   r   HncValueValuesEnumr2  }
  rx   r   r3  r   r#   r   N)r   r   r   r   r   r   r2   r0  r3  r6   	extensionhncr   r   r   r   r-  r-  ]
  sO     "9>>   !!"<a@)0!4#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/  i
  zState for Hierarchy Controller

Fields:
  state: The deployment state for Hierarchy Controller
  version: The version for Hierarchy Controller
r-  r   HierarchyControllerVersionr#   r   N)
r   r   r   r   r   r   r   r  rz   r   r   r   r   r/  r/  
  s/     
 
 !Eq
I%""#?C'r   r/  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)r7  i
  zVersion for Hierarchy Controller

Fields:
  extension: Version for Hierarchy Controller extension
  hnc: Version for open source HNC
r   r#   r   N)
r   r   r   r   r   r   r%   r4  r5  r   r   r   r   r7  r7  
  s)     ##A&)a #r   r7  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)	r  i
  a  Spec for Annthos Identity Service.

Messages:
  MemberConfigsValue: A map between member ids to their configurations. The
    ID needs to be the full path to the membership e.g.,
    /projects/p/locations/l/memberships/m.

Fields:
  memberConfigs: A map between member ids to their configurations. The ID
    needs to be the full path to the membership e.g.,
    /projects/p/locations/l/memberships/m.
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	)
-IdentityServiceFeatureSpec.MemberConfigsValuei
  aA  A map between member ids to their configurations. The ID needs to be
the full path to the membership e.g.,
/projects/p/locations/l/memberships/m.

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

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

Fields:
  key: Name of the additional property.
  value: A MemberConfig attribute.
r   r  r#   r   Nr   r   r   r   r   r=  
  s+    
 !!!$c$$^Q7er   r   r   Tr!   r   Nr   r   r   r   MemberConfigsValuer;  
  s2    
	8Y.. 	8 %112FTXYr   r>  r   r   N)r   r   r   r   r   r   r   r   r   r>  r   memberConfigsr   r   r   r   r  r  
  sL     !!"89Z9,, Z :Z4 (()=qA-r   r  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)rr  i
  a  State for Anthos Identity Service

Enums:
  StateValueValuesEnum: Deployment state on this member

Fields:
  failureReason: The reason of the failure.
  installedVersion: Installed AIS version. This is the AIS version installed
    on this member. The values makes sense iff state is OK.
  memberConfig: Membership config state on this member
  state: Deployment state on this member
c                   $    \ rS rSrSrSrSrSrSrg)0IdentityServiceFeatureState.StateValueValuesEnumi
  zDeployment state on this member

Values:
  DEPLOYMENT_STATE_UNSPECIFIED: Unspecified state
  OK: deployment succeeds
  ERROR: Failure with error.
r   r   r#   r   N)	r   r   r   r   r   rr   rn  ru   r   r   r   r   r  rB  
  s     $% 	
BEr   r  r   r#   r  r,   r>   r   N)r   r   r   r   r   r   r2   r  r%   failureReasoninstalledVersionr   memberConfigr6   r  r   r   r   r   rr  rr  
  s_    
Y^^ 
 ''*-**1-'':,


4a
8%r   rr  c                   <    \ rS rSrSr\R                  " S5      rSrg)IdentityServiceOptionsi
  zHolds non-protocol-related configuration options.

Fields:
  sessionDuration: Optional. Determines the lifespan of STS tokens issued by
    Anthos Identity Service.
r   r   N)	r   r   r   r   r   r   r%   sessionDurationr   r   r   r   rG  rG  
  s     ))!,/r   rG  c                   <    \ rS rSrSr\R                  " S5      rSrg)InstallErrori   zzErrors pertaining to the installation of ACM

Fields:
  errorMessage: A string representing the user facing error message
r   r   Nrn  r   r   r   rJ  rJ     rp  r   rJ  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
Srg)r=   i
  a  Configuration for the LDAP Auth flow.

Fields:
  group: Optional. Contains the properties for locating and authenticating
    groups in the directory.
  server: Required. Server settings for the external LDAP server.
  serviceAccount: Required. Contains the credentials of the service account
    which is authorized to perform the LDAP search in the directory. The
    credentials can be supplied by the combination of the DN and password or
    the client certificate.
  user: Required. Defines where users exist in the LDAP directory.
r  r   ServerConfigr#   ServiceAccountConfigr,   
UserConfigr>   r   N)r   r   r   r   r   r   r   r"  serverserviceAccountuserr   r   r   r   r=   r=   
  sR     
 
 
2%!!.!4&))*@!D.			a	0$r   r=   c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
ListFeaturesResponsei  a5  Response message for the `GkeHubDomainFeatureService.ListFeatures`
method.

Fields:
  nextPageToken: A token to request the next page of resources from the
    `ListFeatures` method. The value of an empty string means that there are
    no more resources to return.
  resources: The list of matching Features
r   r	  r#   Tr!   r   N)r   r   r   r   r   r   r%   nextPageTokenr   	resourcesr   r   r   r   rS  rS    s-     ''*-$$YDA)r   rS  c                   `    \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	Sr
g	)
ListLocationsResponsei-  zThe response message for Locations.ListLocations.

Fields:
  locations: A list of locations that matches the specified filter in the
    request.
  nextPageToken: The standard List next-page token.
Locationr   Tr!   r#   r   N)r   r   r   r   r   r   r   	locationsr%   rT  r   r   r   r   rW  rW  -  s-     $$ZTB)''*-r   rW  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
S	rg
)ListOperationsResponsei:  a  The response message for Operations.ListOperations.

Fields:
  nextPageToken: The standard List next-page token.
  operations: A list of operations that matches the specified filter in the
    request.
  unreachable: Unordered list. Unreachable resources. Populated when the
    request sets `ListOperationsRequest.return_partial_success` and reads
    across collections e.g. when attempting to list all resources across all
    supported locations.
r   	Operationr#   Tr!   r,   r   N)r   r   r   r   r   r   r%   rT  r   
operationsr6  r   r   r   r   r[  r[  :  s?    
 ''*-%%k1tD*%%a$7+r   r[  c                       \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " S5      r\R                  " S5      rSrg)	ListReferencesRequestiL  au  The ListResourceMetadataRequest request.

Fields:
  pageSize: The maximum number of items to return. If unspecified, server
    will pick an appropriate default. Server may return fewer items than
    requested. A caller should only rely on response's next_page_token to
    determine if there are more References left to be queried.
  pageToken: The next_page_token value returned from a previous List
    request, if any.
  parent: Required. The parent resource name (target_resource of this
    reference). For example: `//targetservice.googleapis.com/projects/{my-
    project}/locations/{location}/instances/{my-instance}`.
r   r  r#   r,   r   N)r   r   r   r   r   r   r  r  r  r  r%   r  r  r   r   r   r   r_  r_  L  sG     ##Ay/@/@/F/FG(##A&)  #&r   r_  c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
ListReferencesResponsei`  zThe ListReferencesResponse response.

Fields:
  nextPageToken: Token to retrieve the next page of results, or empty if
    there are no more results in the list.
  references: The list of references.
r   r  r#   Tr!   r   N)r   r   r   r   r   r   r%   rT  r   
referencesr   r   r   r   ra  ra  `  s-     ''*-%%k1tD*r   ra  c                   x   \ 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
5      r\R                  " SS5      r\R                  " S5      rSrg)rX  im  aM  A resource that represents a Google Cloud location.

Messages:
  LabelsValue: Cross-service attributes for the location. For example
    {"cloud.googleapis.com/region": "us-east1"}
  MetadataValue: Service-specific metadata. For example the available
    capacity at the given location.

Fields:
  displayName: The friendly name for this location, typically a nearby city
    name. For example, "Tokyo".
  labels: Cross-service attributes for the location. For example
    {"cloud.googleapis.com/region": "us-east1"}
  locationId: The canonical id for this location. For example: `"us-east1"`.
  metadata: Service-specific metadata. For example the available capacity at
    the given location.
  name: Resource name for the location, which may vary between
    implementations. For example: `"projects/example-project/locations/us-
    east1"`
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	)
Location.LabelsValuei  a   Cross-service attributes for the location. For example
{"cloud.googleapis.com/region": "us-east1"}

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)'Location.LabelsValue.AdditionalPropertyi  r  r   r#   r   Nr  r   r   r   r   rg    r  r   r   r   Tr!   r   Nr   r   r   r   r  re    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	)
Location.MetadataValuei  a  Service-specific metadata. For example the available capacity at the
given location.

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))Location.MetadataValue.AdditionalPropertyi  An additional property for a MetadataValue object.

Fields:
  key: Name of the additional property.
  value: A extra_types.JsonValue attribute.
r   rG  r#   r   Nr   r   r   r   r   rk    rH  r   r   r   Tr!   r   Nr   r   r   r   MetadataValueri    r  r   rm  r   r#   r,   r>   r@   r   N)r   r   r   r   r   r   r   r   r   r  rm  r%   displayNamer   r-  
locationIdmetadatarG   r   r   r   r   rX  rX  m  s    * !!"89ZI%% Z :Z0 !!"89Zi'' Z :Z2 %%a(+!!-3&$$Q'*##OQ7(			q	!$r   rX  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
)	LogConfigi  zSpecifies what kind of log the caller must write

Fields:
  cloudAudit: Cloud audit options.
  counter: Counter options.
  dataAccess: Data access options.
r   r   r  r#   r  r,   r   N)r   r   r   r   r   r   r   
cloudAuditcounter
dataAccessr   r   r   r   rr  rr    sB     %%&91=*""#3Q7'%%&91=*r   rr  c                   d    \ rS rSrSr\R                  " SS5      r\R                  " SS5      rSr	g)r  i  a#  LoggingConfig defines the configuration for different types of logs.

Fields:
  defaultConfig: Specified if applying the default routing config to logs
    not specified in other configs.
  fleetScopeLogsConfig: Specified if applying the routing config to all logs
    for all fleet scopes.
RoutingConfigr   r#   r   N)
r   r   r   r   r   r   r   defaultConfigfleetScopeLogsConfigr   r   r   r   r  r    s.     ((!<-"//C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  zThe configuration for a member/cluster

Fields:
  authMethods: A member may support multiple auth methods.
  identityServiceOptions: Optional. non-protocol-related configuration
    options.
r9   r   Tr!   rG  r#   r   N)
r   r   r   r   r   r   r   authMethodsidentityServiceOptionsr   r   r   r   r  r    s1     &&|QF+$112JANr   r  c                   H   \ 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\R                  " SS5      r\R                  " S5      rSrg)r+  i  ax  Configuration for a single cluster. Intended to parallel the
ConfigManagement CR.

Enums:
  ManagementValueValuesEnum: Enables automatic Feature management.

Fields:
  binauthz: Binauthz conifguration for the cluster. Deprecated: This field
    will be ignored and should not be set.
  cluster: The user-specified cluster name used by Config Sync cluster-name-
    selector annotation or ClusterSelector, for applying configs to only a
    subset of clusters. Omit this field if the cluster's fleet membership
    name is used by Config Sync cluster-name-selector annotation or
    ClusterSelector. Set this field if a name different from the cluster's
    fleet membership name is used by Config Sync cluster-name-selector
    annotation or ClusterSelector.
  configSync: Config Sync configuration for the cluster.
  hierarchyController: Hierarchy Controller configuration for the cluster.
    Deprecated: Configuring Hierarchy Controller through the
    configmanagement feature is no longer recommended. Use
    https://github.com/kubernetes-sigs/hierarchical-namespaces instead.
  management: Enables automatic Feature management.
  policyController: Policy Controller configuration for the cluster.
    Deprecated: Configuring Policy Controller through the configmanagement
    feature is no longer recommended. Use the policycontroller feature
    instead.
  version: Version of ACM installed.
c                   $    \ rS rSrSrSrSrSrSrg)*MembershipConfig.ManagementValueValuesEnumi  zEnables automatic Feature management.

Values:
  MANAGEMENT_UNSPECIFIED: Unspecified
  MANAGEMENT_AUTOMATIC: Google will manage the Feature for the cluster.
  MANAGEMENT_MANUAL: User will manually manage the Feature for the
    cluster.
r   r   r#   r   N)	r   r   r   r   r   MANAGEMENT_UNSPECIFIEDMANAGEMENT_AUTOMATICMANAGEMENT_MANUALr   r   r   r   ManagementValueValuesEnumr    s     r   r  rh   r   r#   r;  r,   r)  r>   r@   PolicyControllerrA   rC   r   N)r   r   r   r   r   r   r2   r  r   binauthzr%   cluster
configSynchierarchyControllerr6   
managementpolicyControllerrz   r   r   r   r   r+  r+    s    :)..  ##$4a8(!!!$'%%lA6*!../JAN""#>B*++,>B!!!$'r   r+  c                       \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	\R                  " SS	5      rS
rg)MeshConnectivityi  zStatus of cross cluster load balancing between other clusters in the
mesh.

Enums:
  StateValueValuesEnum: LifecycleState of multicluster load balancing.

Fields:
  details: Explanation of state.
  state: LifecycleState of multicluster load balancing.
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g)%MeshConnectivity.StateValueValuesEnumi&  ab  LifecycleState of multicluster load balancing.

Values:
  LIFECYCLE_STATE_UNSPECIFIED: Unspecified
  DISABLED: DISABLED means that the component is not enabled.
  FAILED_PRECONDITION: FAILED_PRECONDITION means that provisioning cannot
    proceed because of some characteristic of the member cluster.
  PROVISIONING: PROVISIONING means that provisioning is in progress.
  ACTIVE: ACTIVE means that the component is ready for use.
  STALLED: STALLED means that provisioning could not be done.
  NEEDS_ATTENTION: NEEDS_ATTENTION means that the component is ready, but
    some user intervention is required. (For example that the user should
    migrate workloads to a new control plane revision.)
  DEGRADED: DEGRADED means that the component is ready, but operating in a
    degraded state.
  DEPROVISIONING: DEPROVISIONING means that deprovisioning is in progress.
r   r   r#   r,   r>   r@   rA   rC   r   r   Nr  r   r   r   r  r  &  r  r   r  r  r   Tr!   r#   r   Nr  r   r   r   r  r    s@    	Y^^ 8 ""?AE'


4a
8%r   r  c                       \ rS rSrSrSrg)r  iF  zZAn empty spec for metering feature. This is required since Feature proto
requires a spec.
r   Nr   r   r   r   r  r  F  rY   r   r  c                       \ rS rSrSr\R                  " S5      r\R                  " S\R                  R                  S9rSrg)rs  iM  a  Metering Feature State.

Fields:
  lastMeasurementTime: The time stamp of the most recent measurement of the
    number of vCPUs in the cluster.
  preciseLastMeasuredClusterVcpuCapacity: The vCPUs capacity in the cluster
    according to the most recent measurement (1/1000 precision).
r   r#   r  r   N)r   r   r   r   r   r   r%   lastMeasurementTime
FloatFieldr  FLOAT&preciseLastMeasuredClusterVcpuCapacityr   r   r   r   rs  rs  M  s9     "--a0+4+?+?9K\K\KbKb+c(r   rs  c                       \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	\R                  " S5      rSrg)	r  i[  a  MultiClusterIngressFeatureSpec contains the input for the
MultiClusterIngress feature.

Enums:
  BillingValueValuesEnum: Deprecated: This field will be ignored and should
    not be set. Customer's billing structure

Fields:
  billing: Deprecated: This field will be ignored and should not be set.
    Customer's billing structure
  configMembership: Fully-qualified member name which hosts the
    MultiClusterIngress CRD. Example member name: `projects/foo-
    proj/locations/global/memberships/bar`
c                   $    \ rS rSrSrSrSrSrSrg)5MultiClusterIngressFeatureSpec.BillingValueValuesEnumik  zDeprecated: This field will be ignored and should not be set.
Customer's billing structure

Values:
  BILLING_UNSPECIFIED: Unknown
  PAY_AS_YOU_GO: User pays a fee per-endpoint.
  ANTHOS_LICENSE: User is paying for Anthos as a whole.
r   r   r#   r   N)	r   r   r   r   r   BILLING_UNSPECIFIEDPAY_AS_YOU_GOANTHOS_LICENSEr   r   r   r   BillingValueValuesEnumr  k  s     MNr   r  r   r#   r   N)r   r   r   r   r   r   r2   r  r6   billingr%   configMembershipr   r   r   r   r  r  [  s=    y~~   8!<'**1-r   r  c                       \ rS rSrSrSrg)rt  i|  zMultiClusterIngressFeatureState contains the status fields specific to
the MultiClusterIngress feature. This is just a placeholder and more fields
will be added when we have more state information to report for this
feature.
r   Nr   r   r   r   rt  rt  |  r  r   rt  c                       \ rS rSrSrSrg)r  i  zqAn empty spec for multi-cluster service discovery feature. This is
required since Feature proto requires a spec.
r   Nr   r   r   r   r  r    rY   r   r  c                       \ rS rSrSrSrg)ru  i  zyAn empty state for multi-cluster service discovery feature. This is
required since FeatureStateDetails requires a state.
r   Nr   r   r   r   ru  ru    rY   r   ru  c                       \ rS rSrSr " S S\R                  5      r\R                  " S5       " S S\R                  5      5       r\R                  " SS5      r\R                  " SS	5      rS
rg)r  i  aA  An empty spec for FNS actuation feature.

Enums:
  ActuationModeValueValuesEnum: actuation_mode controls the behavior of the
    controller

Messages:
  MembershipConfigsValue: Map of Membership resource name to individual
    configs. Membership resource names are in the format of
    "projects/P/locations/L/memberships/M"

Fields:
  actuationMode: actuation_mode controls the behavior of the controller
  membershipConfigs: Map of Membership resource name to individual configs.
    Membership resource names are in the format of
    "projects/P/locations/L/memberships/M"
c                   $    \ rS rSrSrSrSrSrSrg):NamespaceActuationFeatureSpec.ActuationModeValueValuesEnumi  a  actuation_mode controls the behavior of the controller

Values:
  ACTUATION_MODE_UNSPECIFIED: ACTUATION_MODE_UNSPECIFIED is similar to
    CREATE_AND_DELETE_IF_CREATED in the default controller behavior.
  ACTUATION_MODE_CREATE_AND_DELETE_IF_CREATED:
    ACTUATION_MODE_CREATE_AND_DELETE_IF_CREATED has the controller create
    cluster namespaces for each fleet namespace and it deletes only the
    ones it created, which are identified by a label.
  ACTUATION_MODE_ADD_AND_REMOVE_FLEET_LABELS:
    ACTUATION_MODE_ADD_AND_REMOVE_FLEET_LABELS has the controller only
    apply labels to cluster namespaces to signal fleet namespace
    enablement. It doesn't create or delete cluster namespaces.
r   r   r#   r   N)	r   r   r   r   r   ACTUATION_MODE_UNSPECIFIED+ACTUATION_MODE_CREATE_AND_DELETE_IF_CREATED*ACTUATION_MODE_ADD_AND_REMOVE_FLEET_LABELSr   r   r   r   ActuationModeValueValuesEnumr    s     "#23/12.r   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	)
4NamespaceActuationFeatureSpec.MembershipConfigsValuei  aH  Map of Membership resource name to individual configs. Membership
resource names are in the format of "projects/P/locations/L/memberships/M"

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

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

Fields:
  key: Name of the additional property.
  value: A NamespaceActuationMembershipSpec attribute.
r    NamespaceActuationMembershipSpecr#   r   Nr   r   r   r   r   r    ,    
 !!!$c$$%GKer   r   r   Tr!   r   Nr   r   r   r   r   r    4    
	LY.. 	L %112FTXYr   r   r   r#   r   N)r   r   r   r   r   r   r2   r  r   r   r   r   r6   actuationModer   r   r   r   r   r   r  r    sp    $3Y^^ 3& !!"89Zy00 Z :Z4 %%&DaH-,,-EqIr   r  c                       \ rS rSrSrSrg)rv  i  z!NamespaceActuation Feature State.r   Nr   r   r   r   rv  rv    s    *r   rv  c                       \ rS rSrSrSrg)r  i  z+NamespaceActuation Membership Feature Spec.r   Nr   r   r   r   r  r    s    4r   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Srg	)
r>  i  aQ  OCI repo configuration for a single cluster

Fields:
  gcpServiceAccountEmail: The Google Cloud Service Account Email used for
    auth when secret_type is gcpServiceAccount.
  policyDir: The absolute path of the directory that contains the local
    resources. Default: the root directory of the image.
  secretType: Type of secret configured for access to the Git repo.
  syncRepo: The OCI image repository URL for the package to sync from. e.g.
    `LOCATION-docker.pkg.dev/PROJECT_ID/REPOSITORY_NAME/PACKAGE_NAME`.
  syncWaitSecs: Period in seconds between consecutive syncs. Default: 15.
r   r#   r,   r>   r@   r   N)r   r   r   r   r   r   r%   r  r  r  r  r  r  r   r   r   r   r>  r>    sZ     %003##A&)$$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\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Srg)r?   i  aL  Configuration for OIDC Auth flow.

Fields:
  certificateAuthorityData: PEM-encoded CA for OIDC provider.
  clientId: ID for OIDC client application.
  clientSecret: Input only. Unencrypted OIDC client secret will be passed to
    the GKE Hub CLH.
  deployCloudConsoleProxy: Flag to denote if reverse proxy is used to
    connect to auth provider. This flag should be set to true when provider
    is not reachable by Google Cloud Console.
  enableAccessToken: Enable access token.
  encryptedClientSecret: Output only. Encrypted OIDC Client secret
  extraParams: Comma-separated list of key-value pairs.
  groupPrefix: Prefix to prepend to group name.
  groupsClaim: Claim in OIDC ID token that holds group information.
  issuerUri: URI for the OIDC provider. This should point to the level below
    .well-known/openid-configuration.
  kubectlRedirectUri: Registered redirect uri to redirect users going
    through OAuth flow using kubectl plugin.
  scopes: Comma-separated list of identifiers.
  userClaim: Claim in OIDC ID token that holds username.
  userPrefix: Prefix to prepend to user name.
r   r#   r,   r>   r@   rA   rC   r   r   r   r   r   r   r   r   N)r   r   r   r   r   r   r%   certificateAuthorityDatar_   r`   r4   deployCloudConsoleProxyenableAccessTokenra   rb   extraParamsgroupPrefixgroupsClaim	issuerUrird   scopesrf   
userPrefixr   r   r   r   r?   r?     s    0 '2215""1%(&&q),%2215,,Q/#..q1%%a(+%%a(+%%a(+##B') ,,R0  $&##B')$$R(*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)	OnClusterStatei  a  OnClusterState represents the state of a sub-component of Policy
Controller.

Enums:
  StateValueValuesEnum: The lifecycle state of this component.

Fields:
  details: Surface potential errors or information logs.
  state: The lifecycle state of this component.
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g)#OnClusterState.StateValueValuesEnumi*  aL  The lifecycle state of this component.

Values:
  LIFECYCLE_STATE_UNSPECIFIED: The lifecycle state is unspecified.
  NOT_INSTALLED: Policy Controller (PC) does not exist on the given
    cluster, and no k8s resources of any type that are associated with the
    PC should exist there. The cluster does not possess a membership with
    the Hub Feature controller.
  INSTALLING: The Hub Feature controller possesses a Membership, however
    Policy Controller is not fully installed on the cluster. In this state
    the hub can be expected to be taking actions to install the PC on the
    cluster.
  ACTIVE: Policy Controller (PC) is fully installed on the cluster and in
    an operational mode. In this state the Hub Feature controller will be
    reconciling state with the PC, and the PC will be performing it's
    operational tasks per that software. Entering a READY state requires
    that the hub has confirmed the PC is installed and its pods are
    operational with the version of the PC the Hub Feature controller
    expects.
  UPDATING: Policy Controller (PC) is fully installed, but in the process
    of changing the configuration (including changing the version of PC
    either up and down, or modifying the manifests of PC) of the resources
    running on the cluster. The Hub Feature controller has a Membership,
    is aware of the version the cluster should be running in, but has not
    confirmed for itself that the PC is running with that version.
  DECOMMISSIONING: Policy Controller (PC) may have resources on the
    cluster, but the Hub Feature controller wishes to remove the
    Membership. The Membership still exists.
  CLUSTER_ERROR: Policy Controller (PC) is not operational, and the Hub
    Feature controller is unable to act to make it operational. Entering a
    CLUSTER_ERROR state happens automatically when the PCH determines that
    a PC installed on the cluster is non-operative or that the cluster
    does not meet requirements set for the Hub Feature controller to
    administer the cluster but has nevertheless been given an instruction
    to do so (such as 'install').
  HUB_ERROR: In this state, the PC may still be operational, and only the
    Hub Feature controller is unable to act. The hub should not issue
    instructions to change the PC state, or otherwise interfere with the
    on-cluster resources. Entering a HUB_ERROR state happens automatically
    when the Hub Feature controller determines the hub is in an unhealthy
    state and it wishes to 'take hands off' to avoid corrupting the PC or
    other data.
  SUSPENDED: Policy Controller (PC) is installed but suspended. This means
    that the policies are not enforced, but violations are still recorded
    (through audit).
  DETACHED: PoCo Hub is not taking any action to reconcile cluster
    objects. Changes to those objects will not be overwritten by PoCo Hub.
r   r   r#   r,   r>   r@   rA   rC   r   r   r   Nr   r   r   r   r   r  rs   r}  r  r  DECOMMISSIONINGCLUSTER_ERROR	HUB_ERROR	SUSPENDEDDETACHEDr   r   r   r   r  r  *  s=    /` #$MJFHOMIIHr   r  r   r#   r   N)r   r   r   r   r   r   r2   r  r%   r"  r6   r  r   r   r   r   r  r    s=    	:Y^^ :x !!!$'


4a
8%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)r\  ij  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`.
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.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  rl  r   rG  r#   r   Nr   r   r   r   r   r    rH  r   r   r   Tr!   r   Nr   r   r   r   rm  r    s4    	AY.. 	A %112FTXYr   rm  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   rG  r#   r   Nr   r   r   r   r   r    rH  r   r   r   Tr!   r   Nr   r   r   r   ResponseValuer    s4     	AY.. 	A %112FTXYr   r  r   r  r#   r,   r>   r@   r   N)r   r   r   r   r   r   r   r   r   rm  r  r4   doner   errorrp  r%   rG   responser   r   r   r   r\  r\  j  s    'R !!"89Zi'' Z :Z6 !!"89Zi'' Z :Z< 
			"$

 
 !2A
6%##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)OperationMetadatai  a  Represents the metadata of the long-running operation.

Fields:
  apiVersion: Output only. API version used to start the operation.
  cancelRequested: Output only. Identifies whether the user has requested
    cancellation of the operation. Operations that have successfully been
    cancelled have Operation.error value with a google.rpc.Status.code of 1,
    corresponding to `Code.CANCELLED`.
  createTime: Output only. The time the operation was created.
  endTime: Output only. The time the operation finished running.
  statusDetail: Output only. Human-readable status of the operation, if any.
  target: Output only. Server-defined resource path for the target of the
    operation.
  verb: Output only. Name of the verb executed by the operation.
r   r#   r,   r>   r@   rA   rC   r   N)r   r   r   r   r   r   r%   
apiVersionr4   cancelRequestedr%  endTimestatusDetailtargetverbr   r   r   r   r  r    sy      $$Q'***1-/$$Q'*!!!$'&&q),  #&			q	!$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\R                  " S
5      rSrg)r0  i  a  State information for an ACM's Operator

Enums:
  DeploymentStateValueValuesEnum: The state of the Operator's deployment

Fields:
  deploymentState: The state of the Operator's deployment
  errors: Install errors.
  version: The semenatic version number of the operator
c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
,OperatorState.DeploymentStateValueValuesEnumi  a?  The state of the Operator's deployment

Values:
  DEPLOYMENT_STATE_UNSPECIFIED: Deployment's state cannot be determined
  NOT_INSTALLED: Deployment is not installed
  INSTALLED: Deployment is installed
  ERROR: Deployment was attempted to be installed, but has errors
  PENDING: Deployment is installing or terminating
r   r   r#   r,   r>   r   Nrq   r   r   r   DeploymentStateValueValuesEnumr    rx   r   r  r   rJ  r#   Tr!   r,   r   N)r   r   r   r   r   r   r2   r  r6   r  r   r  r%   rz   r   r   r   r   r0  r0    sP    	y~~   ''(H!L/!!.!dC&!!!$'r   r0  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
SSS9r\R                  " S\R                  R                  S9rSrg)Policyi  ak  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.
  rules: If more than one rule is specified, the rules are applied in the
    following manner: - All matching LOG rules are always applied. - If any
    DENY/DENY_WITH_LOG rule matches, permission is denied. Logging will be
    applied if one or more matching rule requires logging. - Otherwise, if
    any ALLOW/ALLOW_WITH_LOG rule matches, permission is granted. Logging
    will be applied if one or more matching rule requires logging. -
    Otherwise, if no rule applies, permission is denied.
  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,   Ruler>   r@   r  r   N)r   r   r   r   r   r   r   auditConfigsbindingsra   etagrulesr  r  r  rz   r   r   r   r   r  r    su    L\ ''q4H,##Iq4@(			a	 $

 
 T
:%""1i.?.?.E.EF'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S5      rS	rg
)PolicyContentSpecig  a  PolicyContentSpec defines the user's desired content configuration on
the cluster.

Messages:
  BundlesValue: map of bundle name to BundleInstallSpec. The bundle name
    maps to the `bundleName` key in the
    `policycontroller.gke.io/constraintData` annotation on a constraint.

Fields:
  bundles: map of bundle name to BundleInstallSpec. The bundle name maps to
    the `bundleName` key in the `policycontroller.gke.io/constraintData`
    annotation on a constraint.
  templateLibrary: Configures the installation of the Template Library.
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	)
PolicyContentSpec.BundlesValueiw  aA  map of bundle name to BundleInstallSpec. The bundle name maps to the
`bundleName` key in the `policycontroller.gke.io/constraintData`
annotation on a constraint.

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

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

Fields:
  key: Name of the additional property.
  value: A BundleInstallSpec attribute.
r   r   r#   r   Nr   r   r   r   r   r    s,    
 !!!$c$$%8!<er   r   r   Tr!   r   Nr   r   r   r   BundlesValuer  w  s2    		=Y.. 	= %112FTXYr   r  r   TemplateLibraryConfigr#   r   N)r   r   r   r   r   r   r   r   r   r  r   bundlestemplateLibraryr   r   r   r   r  r  g  s^     !!"89ZY&& Z :Z2 "">15'**+BAF/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S5      r\R                  " SS	5      rS
rg)PolicyContentStatei  a3  The state of the policy controller policy content

Messages:
  BundleStatesValue: The state of the any bundles included in the chosen
    version of the manifest

Fields:
  bundleStates: The state of the any bundles included in the chosen version
    of the manifest
  referentialSyncConfigState: The state of the referential data sync
    configuration. This could represent the state of either the syncSet
    object(s) or the config object, depending on the version of PoCo
    configured by the user.
  templateLibraryState: The state of the template library
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	)
$PolicyContentState.BundleStatesValuei  zThe state of the any bundles included in the chosen version of the
manifest

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

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

Fields:
  key: Name of the additional property.
  value: A OnClusterState attribute.
r   r  r#   r   Nr   r   r   r   r   r    ,    
 !!!$c$$%5q9er   r   r   Tr!   r   Nr   r   r   r   BundleStatesValuer    s2    		:Y.. 	: %112FTXYr   r  r   r  r#   r,   r   N)r   r   r   r   r   r   r   r   r   r  r   bundleStatesreferentialSyncConfigStatetemplateLibraryStater   r   r   r   r  r    st      !!"89Z)++ Z :Z2 ''(;Q?,(556FJ"//0@!D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\R                  " S5      r\R                  " S5      r\R                  " S5      rSrg)r  i  a  Configuration for Policy Controller

Fields:
  auditIntervalSeconds: Sets the interval for Policy Controller Audit Scans
    (in seconds). When set to 0, this disables audit functionality
    altogether.
  enabled: Enables the installation of Policy Controller. If false, the rest
    of PolicyController fields take no effect.
  exemptableNamespaces: The set of namespaces that are excluded from Policy
    Controller checks. Namespaces do not need to currently exist on the
    cluster.
  logDeniesEnabled: Logs all denies and dry run failures.
  monitoring: Monitoring specifies the configuration of monitoring.
  mutationEnabled: Enable users to try out mutation for PolicyController.
  referentialRulesEnabled: Enables the ability to use Constraint Templates
    that reference to objects other than the object currently being
    evaluated.
  templateLibraryInstalled: Installs the default template library along with
    Policy Controller.
  updateTime: Output only. Last time this membership spec was updated.
r   r#   r,   Tr!   r>   PolicyControllerMonitoringr@   rA   rC   r   r   r   N)r   r   r   r   r   r   r  auditIntervalSecondsr4   rj   r%   exemptableNamespaceslogDeniesEnabledr   r  mutationEnabledreferentialRulesEnabledtemplateLibraryInstalledr7  r   r   r   r   r  r    s    , #//2""1%'"..q4@++A.%%&BAF***1-/%2215&33A6$$Q'*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	S
SS9r\R                  " S5      rSrg) PolicyControllerDeploymentConfigi  a  Deployment-specific configuration.

Enums:
  PodAffinityValueValuesEnum: Pod affinity configuration.

Fields:
  containerResources: Container resource requirements.
  podAffinity: Pod affinity configuration.
  podAntiAffinity: Pod anti-affinity enablement. Deprecated: use
    `pod_affinity` instead.
  podTolerations: Pod tolerations of node taints.
  replicaCount: Pod replica count.
c                   $    \ rS rSrSrSrSrSrSrg);PolicyControllerDeploymentConfig.PodAffinityValueValuesEnumi  a3  Pod affinity configuration.

Values:
  AFFINITY_UNSPECIFIED: No affinity configuration has been specified.
  NO_AFFINITY: Affinity configurations will be removed from the
    deployment.
  ANTI_AFFINITY: Anti-affinity configuration will be applied to this
    deployment. Default for admissions deployment.
r   r   r#   r   N)	r   r   r   r   r   AFFINITY_UNSPECIFIEDNO_AFFINITYANTI_AFFINITYr   r   r   r   PodAffinityValueValuesEnumr    s     KMr   r  ResourceRequirementsr   r#   r,   
Tolerationr>   Tr!   r@   r   N)r   r   r   r   r   r   r2   r  r   containerResourcesr6   podAffinityr4   podAntiAffinitypodTolerationsr  replicaCountr   r   r   r   r  r    st    9>>  !--.DaH##$@!D+**1-/)),DI.''*,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)	r  i  zSpec for Policy Controller.

Messages:
  MembershipSpecsValue: Map of Membership IDs to individual specs.

Fields:
  membershipSpecs: Map of Membership IDs to individual specs.
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	)
0PolicyControllerFeatureSpec.MembershipSpecsValuei  zMap of Membership IDs to individual specs.

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

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

Fields:
  key: Name of the additional property.
  value: A PolicyControllerMembershipSpec attribute.
r   PolicyControllerMembershipSpecr#   r   Nr   r   r   r   r   r  !  s,    
 !!!$c$$%EqIer   r   r   Tr!   r   Nr   r   r   r   MembershipSpecsValuer    s4    	JY.. 	J %112FTXYr   r  r   r   N)r   r   r   r   r   r   r   r   r   r  r   membershipSpecsr   r   r   r   r  r    sL     !!"89ZY.. Z :Z0 **+A1E/r   r  c                      \ rS rSrSr " S S\R                  5      r\R                  " S5       " S S\R                  5      5       r\R                  " SS5      r\R                  " S	S
5      r\R                  " SS5      rSrg)rw  i1  a  State for PolicyController

Enums:
  StateValueValuesEnum: The overall Policy Controller lifecycle state
    observed by the Hub Feature controller.

Messages:
  ComponentStatesValue: On-cluster states of the components we would like to
    track. Currently these include (also serving as map keys): 1.
    "admission" 2. "audit" 3. "mutation"

Fields:
  componentStates: On-cluster states of the components we would like to
    track. Currently these include (also serving as map keys): 1.
    "admission" 2. "audit" 3. "mutation"
  policyContentState: The overall content state observed by the Hub Feature
    controller.
  state: The overall Policy Controller lifecycle state observed by the Hub
    Feature controller.
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g)1PolicyControllerFeatureState.StateValueValuesEnumiG  a{  The overall Policy Controller lifecycle state observed by the Hub
Feature controller.

Values:
  LIFECYCLE_STATE_UNSPECIFIED: The lifecycle state is unspecified.
  NOT_INSTALLED: Policy Controller (PC) does not exist on the given
    cluster, and no k8s resources of any type that are associated with the
    PC should exist there. The cluster does not possess a membership with
    the Hub Feature controller.
  INSTALLING: The Hub Feature controller possesses a Membership, however
    Policy Controller is not fully installed on the cluster. In this state
    the hub can be expected to be taking actions to install the PC on the
    cluster.
  ACTIVE: Policy Controller (PC) is fully installed on the cluster and in
    an operational mode. In this state the Hub Feature controller will be
    reconciling state with the PC, and the PC will be performing it's
    operational tasks per that software. Entering a READY state requires
    that the hub has confirmed the PC is installed and its pods are
    operational with the version of the PC the Hub Feature controller
    expects.
  UPDATING: Policy Controller (PC) is fully installed, but in the process
    of changing the configuration (including changing the version of PC
    either up and down, or modifying the manifests of PC) of the resources
    running on the cluster. The Hub Feature controller has a Membership,
    is aware of the version the cluster should be running in, but has not
    confirmed for itself that the PC is running with that version.
  DECOMMISSIONING: Policy Controller (PC) may have resources on the
    cluster, but the Hub Feature controller wishes to remove the
    Membership. The Membership still exists.
  CLUSTER_ERROR: Policy Controller (PC) is not operational, and the Hub
    Feature controller is unable to act to make it operational. Entering a
    CLUSTER_ERROR state happens automatically when the PCH determines that
    a PC installed on the cluster is non-operative or that the cluster
    does not meet requirements set for the Hub Feature controller to
    administer the cluster but has nevertheless been given an instruction
    to do so (such as 'install').
  HUB_ERROR: In this state, the PC may still be operational, and only the
    Hub Feature controller is unable to act. The hub should not issue
    instructions to change the PC state, or otherwise interfere with the
    on-cluster resources. Entering a HUB_ERROR state happens automatically
    when the Hub Feature controller determines the hub is in an unhealthy
    state and it wishes to 'take hands off' to avoid corrupting the PC or
    other data.
  SUSPENDED: Policy Controller (PC) is installed but suspended. This means
    that the policies are not enforced, but violations are still recorded
    (through audit).
  DETACHED: PoCo Hub is not taking any action to reconcile cluster
    objects. Changes to those objects will not be overwritten by PoCo Hub.
r   r   r#   r,   r>   r@   rA   rC   r   r   r   Nr  r   r   r   r  r  G  s=    0b #$MJFHOMIIHr   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	)
1PolicyControllerFeatureState.ComponentStatesValuei  aK  On-cluster states of the components we would like to track. Currently
these include (also serving as map keys): 1. "admission" 2. "audit" 3.
"mutation"

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

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

Fields:
  key: Name of the additional property.
  value: A OnClusterState attribute.
r   r  r#   r   Nr   r   r   r   r   r!    r  r   r   r   Tr!   r   Nr   r   r   r   ComponentStatesValuer    s2    
	:Y.. 	: %112FTXYr   r"  r   r  r#   r,   r   N)r   r   r   r   r   r   r2   r  r   r   r   r"  r   componentStatespolicyContentStater6   r  r   r   r   r   rw  rw  1  s    *;Y^^ ;z !!"89ZY.. Z :Z4 **+A1E/ --.BAF


4a
8%r   rw  c                      \ rS rSrSr " S S\R                  5      r\R                  " S5       " S S\R                  5      5       r\R                  " S5      r\R                  " S	5      r\R                  " SS
5      r\R"                  " SSS9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)PolicyControllerHubConfigi  a  Configuration for Policy Controller.

Enums:
  InstallSpecValueValuesEnum: The install_spec represents the intended state
    specified by the latest request that mutated install_spec in the feature
    spec, not the lifecycle state of the feature observed by the Hub feature
    controller that is reported in the feature state.

Messages:
  DeploymentConfigsValue: Map of deployment configs to deployments
    ("admission", "audit", "mutation").

Fields:
  auditIntervalSeconds: Sets the interval for Policy Controller Audit Scans
    (in seconds). When set to 0, this disables audit functionality
    altogether.
  constraintViolationLimit: The maximum number of audit violations to be
    stored in a constraint. If not set, the internal default (currently 20)
    will be used.
  deploymentConfigs: Map of deployment configs to deployments ("admission",
    "audit", "mutation").
  exemptableNamespaces: The set of namespaces that are excluded from Policy
    Controller checks. Namespaces do not need to currently exist on the
    cluster.
  installSpec: The install_spec represents the intended state specified by
    the latest request that mutated install_spec in the feature spec, not
    the lifecycle state of the feature observed by the Hub feature
    controller that is reported in the feature state.
  logDeniesEnabled: Logs all denies and dry run failures.
  monitoring: Monitoring specifies the configuration of monitoring.
  mutationEnabled: Enables the ability to mutate resources using Policy
    Controller.
  policyContent: Specifies the desired policy content on the cluster
  referentialRulesEnabled: Enables the ability to use Constraint Templates
    that reference to objects other than the object currently being
    evaluated.
c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
4PolicyControllerHubConfig.InstallSpecValueValuesEnumi  a  The install_spec represents the intended state specified by the latest
request that mutated install_spec in the feature spec, not the lifecycle
state of the feature observed by the Hub feature controller that is
reported in the feature state.

Values:
  INSTALL_SPEC_UNSPECIFIED: Spec is unknown.
  INSTALL_SPEC_NOT_INSTALLED: Request to uninstall Policy Controller.
  INSTALL_SPEC_ENABLED: Request to install and enable Policy Controller.
  INSTALL_SPEC_SUSPENDED: Request to suspend Policy Controller i.e. its
    webhooks. If Policy Controller is not installed, it will be installed
    but suspended.
  INSTALL_SPEC_DETACHED: Request to stop all reconciliation actions by
    PoCo Hub controller. This is a breakglass mechanism to stop PoCo Hub
    from affecting cluster resources.
r   r   r#   r,   r>   r   N)r   r   r   r   r   INSTALL_SPEC_UNSPECIFIEDINSTALL_SPEC_NOT_INSTALLEDINSTALL_SPEC_ENABLEDINSTALL_SPEC_SUSPENDEDINSTALL_SPEC_DETACHEDr   r   r   r   InstallSpecValueValuesEnumr(    s'       !!"r   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	)
0PolicyControllerHubConfig.DeploymentConfigsValuei  a  Map of deployment configs to deployments ("admission", "audit",
"mutation").

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

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

Fields:
  key: Name of the additional property.
  value: A PolicyControllerDeploymentConfig attribute.
r   r  r#   r   Nr   r   r   r   r   r2    r  r   r   r   Tr!   r   Nr   r   r   r   DeploymentConfigsValuer0    r  r   r3  r   r#   r,   r>   Tr!   r@   rA    PolicyControllerMonitoringConfigrC   r   r  r   r   r   N)r   r   r   r   r   r   r2   r.  r   r   r   r3  r  r  constraintViolationLimitr   deploymentConfigsr%   r  r6   installSpecr4   r   r  r  policyContentr  r   r   r   r   r&  r&    s    $L9>> . !!"89Zy00 Z :Z4 #//2&33A6,,-EqI"..q4@##$@!D+++A.%%&H!L***1-/(()<a@-%2226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  Configuration for a single cluster. Intended to parallel the
PolicyController CR.

Fields:
  policyControllerHubConfig: Policy Controller configuration for the
    cluster, managed by the Policy Controller Hub Feature controller.
  version: The version of the Policy Controller Feature.
r&  r   r#   r   N)r   r   r   r   r   r   r   policyControllerHubConfigr%   rz   r   r   r   r   r  r  	  s.     (445PRST!!!$'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)	PolicyControllerMigrationi  zState for the migration of PolicyController from ACM -> PoCo Hub.

Enums:
  StageValueValuesEnum: Stage of the migration.

Fields:
  copyTime: Last time this membership spec was copied to PoCo feature.
  stage: Stage of the migration.
c                   $    \ rS rSrSrSrSrSrSrg).PolicyControllerMigration.StageValueValuesEnumi"  a  Stage of the migration.

Values:
  STAGE_UNSPECIFIED: Unknown state of migration.
  ACM_MANAGED: ACM Hub/Operator manages policycontroller. No migration yet
    completed.
  POCO_MANAGED: All migrations steps complete; Poco Hub now manages
    policycontroller.
r   r   r#   r   N)	r   r   r   r   r   STAGE_UNSPECIFIEDACM_MANAGEDPOCO_MANAGEDr   r   r   r   StageValueValuesEnumr>  "  s     KLr   rB  r   r#   r   N)r   r   r   r   r   r   r2   rB  r%   copyTimer6   stager   r   r   r   r<  r<    s<    Y^^  ""1%(


4a
8%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	)
r  i4  a  PolicyControllerMonitoring specifies the backends Policy Controller
should export metrics to. For example, to specify metrics should be exported
to Cloud Monitoring and Prometheus, specify backends: ["cloudmonitoring",
"prometheus"]

Enums:
  BackendsValueListEntryValuesEnum:

Fields:
  backends: Specifies the list of backends Policy Controller will export to.
    An empty list would effectively disable metrics export.
c                   $    \ rS rSrSrSrSrSrSrg);PolicyControllerMonitoring.BackendsValueListEntryValuesEnumiB  BackendsValueListEntryValuesEnum enum type.

Values:
  MONITORING_BACKEND_UNSPECIFIED: Backend cannot be determined
  PROMETHEUS: Prometheus backend for monitoring
  CLOUD_MONITORING: Stackdriver/Cloud Monitoring backend for monitoring
r   r   r#   r   N	r   r   r   r   r   MONITORING_BACKEND_UNSPECIFIED
PROMETHEUSCLOUD_MONITORINGr   r   r   r    BackendsValueListEntryValuesEnumrG  B       &'"Jr   rM  r   Tr!   r   Nr   r   r   r   r   r   r2   rM  r6   backendsr   r   r   r   r  r  4  /    
 
   !CQQUV(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	)
r4  iQ  a  PolicyControllerMonitoringConfig specifies the backends Policy
Controller should export metrics to. For example, to specify metrics should
be exported to Cloud Monitoring and Prometheus, specify backends:
["prometheus", "cloudmonitoring"]

Enums:
  BackendsValueListEntryValuesEnum:

Fields:
  backends: Specifies the list of backends Policy Controller will export to.
    An empty list would effectively disable metrics export.
c                   $    \ rS rSrSrSrSrSrSrg)APolicyControllerMonitoringConfig.BackendsValueListEntryValuesEnumi_  rH  r   r   r#   r   NrI  r   r   r   rM  rT  _  rN  r   rM  r   Tr!   r   NrO  r   r   r   r4  r4  Q  rQ  r   r4  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
)r1  in  zState for PolicyControllerState.

Fields:
  deploymentState: The state about the policy controller installation.
  migration: Record state of ACM -> PoCo Hub migration for this feature.
  version: The version of Gatekeeper Policy Controller deployed.
r  r   r<  r#   PolicyControllerVersionr,   r   N)r   r   r   r   r   r   r   r  	migrationrz   r   r   r   r   r1  r1  n  sB     **+FJ/$$%@!D)""#<a@'r   r1  c                   <    \ rS rSrSr\R                  " S5      rSrg)rV  i|  zThe build version of Gatekeeper Policy Controller is using.

Fields:
  version: The gatekeeper image tag that is composed of ACM version, git
    tag, build number.
r   r   N)	r   r   r   r   r   r   r%   rz   r   r   r   r   rV  rV  |  s     !!!$'r   rV  c                   <    \ rS rSrSr\R                  " S5      rSrg)r  i  z**RBAC RoleBinding Actuation**: The Hub-wide input for the
RBACRoleBindingActuation feature.

Fields:
  actuationDisabled: A boolean attribute.
r   r   N)	r   r   r   r   r   r   r4   actuationDisabledr   r   r   r   r  r    s      ,,Q/r   r  c                       \ rS rSrSrSrg)rx  i  z[**RBAC RoleBinding Actuation**: An empty state left as an example Hub-
wide Feature state.
r   Nr   r   r   r   rx  rx    rY   r   rx  c                   D   \ 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
5      r\R                  " S5      r\R                  " S5      r\R                  " S5      rSrg)r  i  a  Represents a reference to a resource.

Messages:
  DetailsValueListEntry: A DetailsValueListEntry object.

Fields:
  createTime: Output only. The creation time.
  details: Details of the reference type with no implied semantics.
    Cumulative size of the field must not be more than 1KiB.
  name: Output only. Relative resource name of the reference. Includes
    target resource as a parent and reference uid
    `{target_resource}/references/{reference_id}`. For example,
    `projects/{my-project}/locations/{location}/instances/{my-
    instance}/references/{xyz}`.
  sourceResource: Required. Full resource name of the resource which refers
    the target resource. For example:
    //tpu.googleapis.com/projects/myproject/nodes/mynode
  targetUniqueId: Output only. The unique_id of the target resource. Example
    1: (For arcus resource) A-1-0-2-387420123-13-913517247483640811
    unique_id format defined in go/m11n-unique-id-as-resource-id Example 2:
    (For CCFE resource) 123e4567-e89b-12d3-a456-426614174000
  type: Required. Type of the reference. A service might impose limits on
    number of references of a specific type. Note: It's recommended to use
    CAPITALS_WITH_UNDERSCORES style for a type name.
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	)
Reference.DetailsValueListEntryi  r  c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)2Reference.DetailsValueListEntry.AdditionalPropertyi  r  r   rG  r#   r   Nr   r   r   r   r   r`    rH  r   r   r   Tr!   r   Nr   r   r   r   r  r^    r  r   r  r   r#   Tr!   r,   r>   r@   rA   r   N)r   r   r   r   r   r   r   r   r   r  r%   r%  r   r"  rG   sourceResourcetargetUniqueIdr  r   r   r   r   r  r    s    4 !!"89Zi// Z :Z2 $$Q'*""#:AM'			q	!$((+.((+.			q	!$r   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)ResourceListi  zResourceList contains container resource requirements.

Fields:
  cpu: CPU requirement expressed in Kubernetes resource units.
  memory: Memory requirement expressed in Kubernetes resource units.
r   r#   r   N)
r   r   r   r   r   r   r%   cpumemoryr   r   r   r   rd  rd    s)     	a #  #&r   rd  c                   d    \ rS rSrSr\R                  " SS5      r\R                  " SS5      rSr	g)r  i  a1  ResourceRequirements describes the compute resource requirements.

Fields:
  limits: Limits describes the maximum amount of compute resources allowed
    for use by the running container.
  requests: Requests describes the amount of compute resources reserved for
    the container by the kube-scheduler.
rd  r   r#   r   N)
r   r   r   r   r   r   r   limitsrequestsr   r   r   r   r  r    s-     !!.!4&##NA6(r   r  c                   h    \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	Sr
g)rw  i  zRoutingConfig configures the behaviour of fleet logging feature.

Enums:
  ModeValueValuesEnum: mode configures the logs routing mode.

Fields:
  mode: mode configures the logs routing mode.
c                   $    \ rS rSrSrSrSrSrSrg)!RoutingConfig.ModeValueValuesEnumi  zmode configures the logs routing mode.

Values:
  MODE_UNSPECIFIED: If UNSPECIFIED, fleet logging feature is disabled.
  COPY: logs will be copied to the destination project.
  MOVE: logs will be moved to the destination project.
r   r   r#   r   N)	r   r   r   r   r   MODE_UNSPECIFIEDCOPYMOVEr   r   r   r   ModeValueValuesEnumrl    s     DDr   rp  r   r   N)r   r   r   r   r   r   r2   rp  r6   moder   r   r   r   rw  rw    s,    
INN 
 
		2A	6$r   rw  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\R                  " S
5      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  A rule to be applied in a Policy.

Enums:
  ActionValueValuesEnum: Required

Fields:
  action: Required
  conditions: Additional restrictions that must be met. All conditions must
    pass for the rule to match.
  description: Human-readable description of the rule.
  in_: If one or more 'in' clauses are specified, the rule matches if the
    PRINCIPAL/AUTHORITY_SELECTOR is in at least one of these entries.
  logConfig: The config returned to callers of CheckPolicy for any entries
    that match the LOG action.
  notIn: If one or more 'not_in' clauses are specified, the rule matches if
    the PRINCIPAL/AUTHORITY_SELECTOR is in none of the entries. The format
    for in and not_in entries can be found at in the Local IAM documentation
    (see go/local-iam#features).
  permissions: A permission is a string of form `..` (e.g.,
    'storage.buckets.list'). A value of '*' matches all permissions, and a
    verb part of '*' (e.g., 'storage.buckets.*') matches all verbs.
c                   0    \ rS rSrSrSrSrSrSrSr	Sr
S	rg
)Rule.ActionValueValuesEnumi!  a  Required

Values:
  NO_ACTION: Default no action.
  ALLOW: Matching 'Entries' grant access.
  ALLOW_WITH_LOG: Matching 'Entries' grant access and the caller promises
    to log the request per the returned log_configs.
  DENY: Matching 'Entries' deny access.
  DENY_WITH_LOG: Matching 'Entries' deny access and the caller promises to
    log the request per the returned log_configs.
  LOG: Matching 'Entries' tell IAM.Check callers to generate logs.
r   r   r#   r,   r>   r@   r   N)r   r   r   r   r   	NO_ACTIONALLOWALLOW_WITH_LOGDENYDENY_WITH_LOGLOGr   r   r   r   ActionValueValuesEnumrt  !  s'     IENDM
Cr   r{  r   r  r#   Tr!   r,   r>   rr  r@   rA   rC   r   N)r   r   r   r   r   r   r2   r{  r6   actionr   
conditionsr%   r  in_	logConfignotInpermissionsr   r   r   r   r  r  	  s    .inn ( 6:&%%&<a$O*%%a(+a$/#$$[!dC)


D
1%%%a$7+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	S
S9r\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                  " S5      rSrg)rB   i>  a  Configuration for the SAML Auth flow.

Messages:
  AttributeMappingValue: Optional. The mapping of additional user attributes
    like nickname, birthday and address etc.. `key` is the name of this
    additional attribute. `value` is a string presenting as CEL(common
    expression language, go/cel) used for getting the value from the
    resources. Take nickname as an example, in this case, `key` is
    "attribute.nickname" and `value` is "assertion.nickname".

Fields:
  attributeMapping: Optional. The mapping of additional user attributes like
    nickname, birthday and address etc.. `key` is the name of this
    additional attribute. `value` is a string presenting as CEL(common
    expression language, go/cel) used for getting the value from the
    resources. Take nickname as an example, in this case, `key` is
    "attribute.nickname" and `value` is "assertion.nickname".
  groupPrefix: Optional. Prefix to prepend to group name.
  groupsAttribute: Optional. The SAML attribute to read groups from. This
    value is expected to be a string and will be passed along as-is (with
    the option of being prefixed by the `group_prefix`).
  identityProviderCertificates: Required. The list of IdP certificates to
    validate the SAML response against.
  identityProviderId: Required. The entity ID of the SAML IdP.
  identityProviderSsoUri: Required. The URI where the SAML IdP exposes the
    SSO service.
  userAttribute: Optional. The SAML attribute to read username from. If
    unspecified, the username will be read from the NameID element of the
    assertion in SAML response. This value is expected to be a string and
    will be passed along as-is (with the option of being prefixed by the
    `user_prefix`).
  userPrefix: Optional. Prefix to prepend to user name.
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	)
 SamlConfig.AttributeMappingValueia  a.  Optional. The mapping of additional user attributes like nickname,
birthday and address etc.. `key` is the name of this additional attribute.
`value` is a string presenting as CEL(common expression language, go/cel)
used for getting the value from the resources. Take nickname as an
example, in this case, `key` is "attribute.nickname" and `value` is
"assertion.nickname".

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

Fields:
  additionalProperties: Additional properties of type
    AttributeMappingValue
c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)3SamlConfig.AttributeMappingValue.AdditionalPropertyis  zAn additional property for a AttributeMappingValue object.

Fields:
  key: Name of the additional property.
  value: A string attribute.
r   r#   r   Nr  r   r   r   r   r  s  r  r   r   r   Tr!   r   Nr   r   r   r   AttributeMappingValuer  a  s2     	'Y.. 	' %112FTXYr   r  r   r#   r,   r>   Tr!   r@   rA   rC   r   r   N)r   r   r   r   r   r   r   r   r   r  r   attributeMappingr%   r  groupsAttributeidentityProviderCertificatesidentityProviderIdidentityProviderSsoUriuserAttributer  r   r   r   r   rB   rB   >  s     D !!"89Zi// Z :Z< ++,CQG%%a(+))!,/!*!6!6q4!H ,,Q/$003''*-$$Q'*r   rB   c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r	\R                  " S5      r
Srg)rL  i  a  Server settings for the external LDAP server.

Fields:
  certificateAuthorityData: Optional. Contains a Base64 encoded, PEM
    formatted certificate authority certificate for the LDAP server. This
    must be provided for the "ldaps" and "startTLS" connections.
  connectionType: Optional. Defines the connection type to communicate with
    the LDAP server. If `starttls` or `ldaps` is specified, the
    certificate_authority_data should not be empty.
  host: Required. Defines the hostname or IP of the LDAP server. Port is
    optional and will default to 389, if unspecified. For example,
    "ldap.server.example" or "10.10.10.10:389".
r   r#   r,   r   N)r   r   r   r   r   r   ra   r  r%   connectionTypehostr   r   r   r   rL  rL    s:     '11!4((+.			q	!$r   rL  c                   >    \ rS rSrSr\R                  " SS5      rSrg)rM  i  a  Contains the credentials of the service account which is authorized to
perform the LDAP search in the directory. The credentials can be supplied by
the combination of the DN and password or the client certificate.

Fields:
  simpleBindCredentials: Credentials for basic auth.
SimpleBindCredentialsr   r   N)	r   r   r   r   r   r   r   simpleBindCredentialsr   r   r   r   rM  rM    s     $001H!Lr   rM  c                       \ rS rSrSrSrg)r  i  zcAn empty spec for service directory feature. This is required since
Feature proto requires a spec.
r   Nr   r   r   r   r  r    rY   r   r  c                       \ rS rSrSrSrg)ry  i  zkAn empty state for service directory feature. This is rqeuired since
FeatureStateDetails requires a state.
r   Nr   r   r   r   ry  ry    rY   r   ry  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
SS9rSrg)ServiceMeshAnalysisMessagei  a  ServiceMeshAnalysisMessage is a single message produced by an analyzer,
and it used to communicate to the end user about the state of their Service
Mesh configuration.

Messages:
  ArgsValue: A UI can combine these args with a template (based on
    message_base.type) to produce an internationalized message.

Fields:
  args: A UI can combine these args with a template (based on
    message_base.type) to produce an internationalized message.
  description: A human readable description of what the error means. It is
    suitable for non-internationalize display purposes.
  messageBase: Details common to all types of Istio and ServiceMesh analysis
    messages.
  resourcePaths: A list of strings specifying the resource identifiers that
    were the cause of message generation. A "path" here may be: *
    MEMBERSHIP_ID if the cause is a specific member cluster *
    MEMBERSHIP_ID/(NAMESPACE\/)?RESOURCETYPE/NAME if the cause is a resource
    in a cluster
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	)
$ServiceMeshAnalysisMessage.ArgsValuei  zA UI can combine these args with a template (based on
message_base.type) to produce an internationalized message.

Messages:
  AdditionalProperty: An additional property for a ArgsValue 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)7ServiceMeshAnalysisMessage.ArgsValue.AdditionalPropertyi  zAn additional property for a ArgsValue object.

Fields:
  key: Name of the additional property.
  value: A extra_types.JsonValue attribute.
r   rG  r#   r   Nr   r   r   r   r   r    rH  r   r   r   Tr!   r   Nr   r   r   r   	ArgsValuer    rJ  r   r  r   r#   ServiceMeshAnalysisMessageBaser,   r>   Tr!   r   N)r   r   r   r   r   r   r   r   r   r  r   argsr%   r  messageBaseresourcePathsr   r   r   r   r  r    s    , !!"89Z)## Z :Z0 
		Q	/$%%a(+&&'GK+''D9-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S	rg
)r  i  a  ServiceMeshAnalysisMessageBase describes some common information that is
needed for all messages.

Enums:
  LevelValueValuesEnum: Represents how severe a message is.

Fields:
  documentationUrl: A url pointing to the Service Mesh or Istio
    documentation for this specific error type.
  level: Represents how severe a message is.
  type: Represents the specific type of a message.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	3ServiceMeshAnalysisMessageBase.LevelValueValuesEnumi  aI  Represents how severe a message is.

Values:
  LEVEL_UNSPECIFIED: Illegal. Same
    istio.analysis.v1alpha1.AnalysisMessageBase.Level.UNKNOWN.
  ERROR: ERROR represents a misconfiguration that must be fixed.
  WARNING: WARNING represents a misconfiguration that should be fixed.
  INFO: INFO represents an informational finding.
r   r   r#   r,   r   N)
r   r   r   r   r   LEVEL_UNSPECIFIEDru   r  r  r   r   r   r   LevelValueValuesEnumr    s     EGDr   r  r   r#   Typer,   r   N)r   r   r   r   r   r   r2   r  r%   documentationUrlr6   levelr   r  r   r   r   r   r  r    sO    Y^^  **1-


4a
8%				*$r   r  c                      \ rS rSrSr " S S\R                  5      r\R                  " S5       " S S\R                  5      5       r\R                  " SS	5      r\R                  " SS
5      r\R                  " SS5      rSrg)r  i  a.  ServiceMeshFeatureSpec contains the input for the service mesh feature.

Enums:
  ModernizationValueValuesEnum: Optional. Specifies modernization for the
    fleet.

Messages:
  MembershipSpecsValue: Optional. Map from full path to the membership, to
    its individual config.

Fields:
  fleetDefaultMemberConfig: Optional. The default fleet configuration to be
    applied to all memberships.
  membershipSpecs: Optional. Map from full path to the membership, to its
    individual config.
  modernization: Optional. Specifies modernization for the fleet.
c                   $    \ rS rSrSrSrSrSrSrg)3ServiceMeshFeatureSpec.ModernizationValueValuesEnumi#  zOptional. Specifies modernization for the fleet.

Values:
  MODERNIZATION_UNSPECIFIED: Unspecified.
  AUTOMATICALLY_MODERNIZED: Google should start modernization.
  BEFORE_MODERNIZATION: Google should rollback fleet.
r   r   r#   r   N)	r   r   r   r   r   MODERNIZATION_UNSPECIFIEDAUTOMATICALLY_MODERNIZEDBEFORE_MODERNIZATIONr   r   r   r   ModernizationValueValuesEnumr  #  s     !" r   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	)
+ServiceMeshFeatureSpec.MembershipSpecsValuei/  zOptional. Map from full path to the membership, to its individual
config.

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

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

Fields:
  key: Name of the additional property.
  value: A ServiceMeshMembershipSpec attribute.
r   r  r#   r   Nr   r   r   r   r   r  <  s,    
 !!!$c$$%@!Der   r   r   Tr!   r   Nr   r   r   r   r  r  /  s4    		EY.. 	E %112FTXYr   r  r  r   r#   r,   r   N)r   r   r   r   r   r   r2   r  r   r   r   r  r   r)  r  r6   modernizationr   r   r   r   r  r    s    $
Y^^ 
 !!"89ZY.. Z :Z2 '334OQRS**+A1E/%%&DaH-r   r  c                   j   \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	\R                  " S	S
SS9r
\R                  " S5      r\R                  " S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Srg)rz  iN  a7  ServiceMeshFeatureState describes the state of the Service Mesh hub
feature as analyzed by the Service Mesh Hub Controller.

Enums:
  DefaultChannelValueValuesEnum: Release channel to use for default
    injection and service mesh APIs.

Fields:
  analysisMessages: Output only. Results of running Service Mesh analyzers
    against member clusters, or the entire mesh.
  conditions: Output only. List of conditions reported for this membership.
  configApiVersion: The API version (i.e. Istio CRD version) for configuring
    service mesh in this cluster. This version is influenced by the
    `default_channel` field.
  controlPlaneManagement: Output only. Status of control plane management
  controlPlaneRevisions: Output only. State of all control plane revisions
    that are available in the cluster.
  dataPlaneManagement: Output only. Status of data plane management.
  defaultChannel: Release channel to use for default injection and service
    mesh APIs.
  meshConnectivity: Output only. Status of cross cluster load balancing
    between other clusters in the mesh.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	5ServiceMeshFeatureState.DefaultChannelValueValuesEnumig  a  Release channel to use for default injection and service mesh APIs.

Values:
  CHANNEL_UNSPECIFIED: Unspecified
  RAPID: RAPID channel is offered on an early access basis for customers
    who want to test new releases.
  REGULAR: REGULAR channel is intended for production users who want to
    take advantage of new features.
  STABLE: STABLE channel includes versions that are known to be stable and
    reliable in production.
r   r   r#   r,   r   Nr  r   r   r   DefaultChannelValueValuesEnumr  g  r  r   r  r  r   Tr!   r   r#   r,   r  r>   r  r@   r  rA   rC   r  r   r   N)r   r   r   r   r   r   r2   r  r   analysisMessagesr}  r%   configApiVersioncontrolPlaneManagementcontrolPlaneRevisionsdataPlaneManagementr6   defaultChannelmeshConnectivityr   r   r   r   rz  rz  N  s    0inn " ++,H!VZ[%%k1tD***1-$112JAN#001GUYZ!../DaH&&'FJ.++,>Br   rz  c                      \ rS rS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\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  **Service Mesh**: Spec for a single Membership for the servicemesh
feature

Enums:
  ConfigApiValueValuesEnum: Optional. Specifies the API that will be used
    for configuring the mesh workloads.
  ControlPlaneValueValuesEnum: Deprecated: use `management` instead Enables
    automatic control plane management.
  DataPlaneValueValuesEnum: Enables automatic data plane management.
  DefaultChannelValueValuesEnum: Determines which release channel to use for
    default injection and service mesh APIs.
  ManagementValueValuesEnum: Optional. Enables automatic Service Mesh
    management.

Fields:
  configApi: Optional. Specifies the API that will be used for configuring
    the mesh workloads.
  controlPlane: Deprecated: use `management` instead Enables automatic
    control plane management.
  dataPlane: Enables automatic data plane management.
  defaultChannel: Determines which release channel to use for default
    injection and service mesh APIs.
  management: Optional. Enables automatic Service Mesh management.
c                   $    \ rS rSrSrSrSrSrSrg)2ServiceMeshMembershipSpec.ConfigApiValueValuesEnumi  zOptional. Specifies the API that will be used for configuring the mesh
workloads.

Values:
  CONFIG_API_UNSPECIFIED: Unspecified
  CONFIG_API_ISTIO: Use the Istio API for configuration.
  CONFIG_API_GATEWAY: Use the K8s Gateway API for configuration.
r   r   r#   r   N)	r   r   r   r   r   CONFIG_API_UNSPECIFIEDCONFIG_API_ISTIOCONFIG_API_GATEWAYr   r   r   r   ConfigApiValueValuesEnumr    s     r   r  c                   $    \ rS rSrSrSrSrSrSrg)5ServiceMeshMembershipSpec.ControlPlaneValueValuesEnumi  a  Deprecated: use `management` instead Enables automatic control plane
management.

Values:
  CONTROL_PLANE_MANAGEMENT_UNSPECIFIED: Unspecified
  AUTOMATIC: Google should provision a control plane revision and make it
    available in the cluster. Google will enroll this revision in a
    release channel and keep it up to date. The control plane revision may
    be a managed service, or a managed install.
  MANUAL: User will manually configure the control plane (e.g. via CLI, or
    via the ControlPlaneRevision KRM API)
r   r   r#   r   N)	r   r   r   r   r   $CONTROL_PLANE_MANAGEMENT_UNSPECIFIED	AUTOMATICMANUALr   r   r   r   ControlPlaneValueValuesEnumr    s     ,-(IFr   r  c                   $    \ rS rSrSrSrSrSrSrg)2ServiceMeshMembershipSpec.DataPlaneValueValuesEnumi  a  Enables automatic data plane management.

Values:
  DATA_PLANE_MANAGEMENT_UNSPECIFIED: Unspecified
  DATA_PLANE_MANAGEMENT_AUTOMATIC: Enables Google-managed data plane that
    provides L7 service mesh capabilities. Data plane management is
    enabled at the cluster level. Users can exclude individual workloads
    or namespaces.
  DATA_PLANE_MANAGEMENT_MANUAL: User will manage their L7 data plane.
r   r   r#   r   N)	r   r   r   r   r   !DATA_PLANE_MANAGEMENT_UNSPECIFIEDDATA_PLANE_MANAGEMENT_AUTOMATICDATA_PLANE_MANAGEMENT_MANUALr   r   r   r   DataPlaneValueValuesEnumr    s    	 )*%&'##$ r   r  c                   (    \ rS rSrSrSrSrSrSrSr	g)	7ServiceMeshMembershipSpec.DefaultChannelValueValuesEnumi  a  Determines which release channel to use for default injection and
service mesh APIs.

Values:
  CHANNEL_UNSPECIFIED: Unspecified
  RAPID: RAPID channel is offered on an early access basis for customers
    who want to test new releases.
  REGULAR: REGULAR channel is intended for production users who want to
    take advantage of new features.
  STABLE: STABLE channel includes versions that are known to be stable and
    reliable in production.
r   r   r#   r,   r   Nr  r   r   r   r  r    s     EGFr   r  c                   (    \ rS rSrSrSrSrSrSrSr	g)	3ServiceMeshMembershipSpec.ManagementValueValuesEnumi  a  Optional. Enables automatic Service Mesh management.

Values:
  MANAGEMENT_UNSPECIFIED: Unspecified
  MANAGEMENT_AUTOMATIC: Google should manage my Service Mesh for the
    cluster.
  MANAGEMENT_MANUAL: User will manually configure their service mesh
    components.
  MANAGEMENT_NOT_INSTALLED: Google should remove any managed Service Mesh
    components from this cluster and deprovision any resources.
r   r   r#   r,   r   N)
r   r   r   r   r   r  r  r  MANAGEMENT_NOT_INSTALLEDr   r   r   r   r  r    s!    
  r   r  r   r#   r,   r>   r@   r   N)r   r   r   r   r   r   r2   r  r  r  r  r  r6   	configApicontrolPlane	dataPlaner  r  r   r   r   r   r  r    s    2 INN "% %inn $!).. !" !!"<a@)$$%BAF,!!"<a@)&&'FJ.""#>B*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
  Request message for `SetIamPolicy` method.

Fields:
  policy: REQUIRED: The complete policy to be applied to the `resource`. The
    size of the policy is limited to a few 10s of KB. An empty policy is a
    valid policy but certain Google Cloud services (such as Projects) might
    reject them.
  updateMask: OPTIONAL: A FieldMask specifying which fields of the policy to
    modify. Only the fields in the mask will be modified. If no mask is
    provided, the following default mask is used: `paths: "bindings, etag"`
r  r   r#   r   N)r   r   r   r   r   r   r   policyr%   r  r   r   r   r   r  r    s+    
 !!(A.&$$Q'*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)r  i  aL  The structure holds the LDAP simple binding credential.

Fields:
  dn: Required. The distinguished name(DN) of the service account
    object/user.
  encryptedPassword: Output only. The encrypted password of the service
    account object/user.
  password: Required. Input only. The password of the service account
    object/user.
r   r#   r,   r   N)r   r   r   r   r   r   r%   dnra   encryptedPasswordpasswordr   r   r   r   r  r    s:    	 Q"**1-""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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.AltValueValuesEnumi0  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  0  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>   r@   rA   rC   r   Tr   r   r   r   r   N)r   r   r   r   r   r   r2   r  r  r6   f__xgafvr%   access_tokenaltcallbackfieldsr   oauth_tokenr4   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 " S S\R                  5      r\R                  " SS5      r	\R                  " S5      rSrg)	r   iT  aD  Status specifies state for the subcomponent.

Enums:
  CodeValueValuesEnum: Code specifies AppDevExperienceFeature's subcomponent
    ready state.

Fields:
  code: Code specifies AppDevExperienceFeature's subcomponent ready state.
  description: Description is populated if Code is Failed, explaining why it
    has failed.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	Status.CodeValueValuesEnumia  a  Code specifies AppDevExperienceFeature's subcomponent ready state.

Values:
  CODE_UNSPECIFIED: Not set.
  OK: AppDevExperienceFeature's specified subcomponent is ready.
  FAILED: AppDevExperienceFeature's specified subcomponent ready state is
    false. This means AppDevExperienceFeature has encountered an issue
    that blocks all, or a portion, of its normal operation. See the
    `description` for more details.
  UNKNOWN: AppDevExperienceFeature's specified subcomponent has a pending
    or unknown state.
r   r   r#   r,   r   N)
r   r   r   r   r   r   rn  ro  UNKNOWNr   r   r   r   r  r  a  s     	
BFGr   r  r   r#   r   N)r   r   r   r   r   r   r2   r  r6   r!  r%   r  r   r   r   r   r   r   T  s<    
INN $ 
		2A	6$%%a(+r   r   c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)r  iw  zStructured and human-readable details for a status.

Fields:
  code: A machine-readable code that further describes a broad status.
  details: Human-readable explanation of code.
r   r#   r   N)
r   r   r   r   r   r   r%   r!  r"  r   r   r   r   r  r  w  s)     
		q	!$!!!$'r   r  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " SSSS9r
S	rg
)	SyncErrori  zAn ACM created error representing a problem syncing configurations

Fields:
  code: An ACM defined error code
  errorMessage: A description of the error
  errorResources: A list of config(s) associated with the error, if any
r   r#   r  r,   Tr!   r   N)r   r   r   r   r   r   r%   r!  ro  r   errorResourcesr   r   r   r   r   r     s=     
		q	!$&&q),))/1tL.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\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  State indicating an ACM's progress syncing configurations to a cluster

Enums:
  CodeValueValuesEnum: Sync status code

Fields:
  code: Sync status code
  errors: A list of errors resulting from problematic configs. This list
    will be truncated after 100 errors, although it is unlikely for that
    many errors to simultaneously exist.
  importToken: Token indicating the state of the importer.
  lastSync: Timestamp of when ACM last successfully synced the repo The time
    format is specified in https://golang.org/pkg/time/#Time.String This
    field is being deprecated. Use last_sync_time instead.
  lastSyncTime: Timestamp type of when ACM last successfully synced the repo
  sourceToken: Token indicating the state of the repo.
  syncToken: Token indicating the state of the syncer.
c                   8    \ 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)SyncState.CodeValueValuesEnumi  a  Sync status code

Values:
  SYNC_CODE_UNSPECIFIED: Config Sync cannot determine a sync code
  SYNCED: Config Sync successfully synced the git Repo with the cluster
  PENDING: Config Sync is in the progress of syncing a new change
  ERROR: Indicates an error configuring Config Sync, and user action is
    required
  NOT_CONFIGURED: Config Sync has been installed but not configured
  NOT_INSTALLED: Config Sync has not been installed
  UNAUTHORIZED: Error authorizing with the cluster
  UNREACHABLE: Cluster could not be reached
r   r   r#   r,   r>   r@   rA   rC   r   N)r   r   r   r   r   SYNC_CODE_UNSPECIFIEDSYNCEDrv   ru   NOT_CONFIGUREDrs   UNAUTHORIZEDUNREACHABLEr   r   r   r   r  r    s2     FGENMLKr   r  r   r   r#   Tr!   r,   r>   r@   rA   rC   r   N)r   r   r   r   r   r   r2   r  r6   r!  r   r  r%   importTokenlastSynclastSyncTimesourceToken	syncTokenr   r   r   r   r  r    s    &INN . 
		2A	6$!!+q4@&%%a(+""1%(&&q),%%a(+##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  i  a,  The config specifying which default library templates to install.

Enums:
  InstallationValueValuesEnum: Configures the manner in which the template
    library is installed on the cluster.

Fields:
  installation: Configures the manner in which the template library is
    installed on the cluster.
c                   $    \ rS rSrSrSrSrSrSrg)1TemplateLibraryConfig.InstallationValueValuesEnumi  a  Configures the manner in which the template library is installed on
the cluster.

Values:
  INSTALLATION_UNSPECIFIED: No installation strategy has been specified.
  NOT_INSTALLED: Do not install the template library.
  ALL: Install the entire template library.
r   r   r#   r   N)	r   r   r   r   r   INSTALLATION_UNSPECIFIEDrs   ALLr   r   r   r   InstallationValueValuesEnumr    s      !M
Cr   r  r   r   N)r   r   r   r   r   r   r2   r  r6   installationr   r   r   r   r  r    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  a3  Request message for `TestIamPermissions` method.

Fields:
  permissions: The set of permissions to check for the `resource`.
    Permissions with wildcards (such as `*` or `storage.*`) are not allowed.
    For more information see [IAM
    Overview](https://cloud.google.com/iam/docs/overview#permissions).
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9rSrg)TestIamPermissionsResponsei  zResponse message for `TestIamPermissions` method.

Fields:
  permissions: A subset of `TestPermissionsRequest.permissions` that the
    caller is allowed.
r   Tr!   r   Nr  r   r   r   r  r    s     %%a$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
Srg)	r  i  zToleration of a node taint.

Fields:
  effect: Matches a taint effect.
  key: Matches a taint key (not necessarily unique).
  operator: Matches a taint operator.
  value: Matches a taint value.
r   r#   r,   r>   r   N)r   r   r   r   r   r   r%   effectr   operatorr   r   r   r   r   r  r    sI       #&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	  a  A unique identifier for the type of message. Display_name is intended to
be human-readable, code is intended to be machine readable. There should be
a one-to-one mapping between display_name and code. (i.e. do not re-use
display_names or codes between message types.) See
istio.analysis.v1alpha1.AnalysisMessageBase.Type

Fields:
  code: A 7 character code matching `^IST[0-9]{4}$` or `^ASM[0-9]{4}$`,
    intended to uniquely identify the message type. (e.g. "IST0001" is
    mapped to the "InternalError" message type.)
  displayName: A human-readable name for the message type. e.g.
    "InternalError", "PodMissingProxy". This should be the same for all
    messages of the same type. (This corresponds to the `name` field in
    open-source Istio.)
r   r#   r   N)
r   r   r   r   r   r   r%   r!  rn  r   r   r   r   r  r  	  s)      
		q	!$%%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)	rN  i  a  Defines where users exist in the LDAP directory.

Fields:
  baseDn: Required. The location of the subtree in the LDAP directory to
    search for user entries.
  filter: Optional. Filter to apply when searching for the user. This can be
    used to further restrict the user accounts which are allowed to login.
    This defaults to "(objectClass=User)".
  idAttribute: Optional. Determines which attribute to use as the user's
    identity after they are authenticated. This is distinct from the
    loginAttribute field to allow users to login with a username, but then
    have their actual identifier be an email address or full Distinguished
    Name (DN). For example, setting loginAttribute to "sAMAccountName" and
    identifierAttribute to "userPrincipalName" would allow a user to login
    as "bsmith", but actual RBAC policies for the user would be written as
    "bsmith@example.com". Using "userPrincipalName" is recommended since
    this will be unique for each user. This defaults to "userPrincipalName".
  loginAttribute: Optional. The name of the attribute which matches against
    the input username. This is used to find the user in the LDAP database
    e.g. "(=)" and is combined with the optional filter field. This defaults
    to "userPrincipalName".
r   r#   r,   r>   r   N)r   r   r   r   r   r   r%   r  r  r   loginAttributer   r   r   r   rN  rN    sI    .   #&  #&%%a(+((+.r   rN  c                      \ rS rSrSr " S S\R                  5      r\R                  " S5       " S S\R                  5      5       r\R                  " SS	5      r\R                  " SS
5      r\R                  " SS5      rSrg)r  i<  a6  WorkloadCertificateFeatureSpec contains the input for the workload
identity platform feature. This is required since Feature proto requires a
spec.

Enums:
  ProvisionGoogleCaValueValuesEnum: Immutable. Specifies CA configuration.

Messages:
  MemberConfigsValue: Per-member configuration of workload certificate.

Fields:
  defaultConfig: Default membership spec. Users can override the default in
    the member_configs for each member.
  memberConfigs: Per-member configuration of workload certificate.
  provisionGoogleCa: Immutable. Specifies CA configuration.
c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
?WorkloadCertificateFeatureSpec.ProvisionGoogleCaValueValuesEnumiN  aA  Immutable. Specifies CA configuration.

Values:
  GOOGLE_CA_PROVISIONING_UNSPECIFIED: Disable default Google managed CA.
  DISABLED: Disable default Google managed CA.
  ENABLED: Use default Google managed CA.
  ENABLED_WITH_MANAGED_CA: Workload certificate feature is enabled, and
    the entire certificate provisioning process is managed by Google with
    managed CAS which is more secure than the default CA.
  ENABLED_WITH_DEFAULT_CA: Workload certificate feature is enabled, and
    the entire certificate provisioning process is using the default CA
    which is free.
r   r   r#   r,   r>   r   N)r   r   r   r   r   "GOOGLE_CA_PROVISIONING_UNSPECIFIEDr  r^  ENABLED_WITH_MANAGED_CAENABLED_WITH_DEFAULT_CAr   r   r   r    ProvisionGoogleCaValueValuesEnumr"  N  s%     *+&HGr   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	)
1WorkloadCertificateFeatureSpec.MemberConfigsValueib  zPer-member configuration of workload certificate.

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

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

Fields:
  key: Name of the additional property.
  value: A WorkloadCertificateMembershipSpec attribute.
r   !WorkloadCertificateMembershipSpecr#   r   Nr   r   r   r   r   r*  n  s,    
 !!!$c$$%H!Ler   r   r   Tr!   r   Nr   r   r   r   r>  r(  b  s4    	MY.. 	M %112FTXYr   r>  r+  r   r#   r,   r   N)r   r   r   r   r   r   r2   r&  r   r   r   r>  r   rx  r?  r6   provisionGoogleCar   r   r   r   r  r  <  s    "   ( !!"89Z9,, Z :Z0 (()LaP-(()=qA-))*LaPr   r  c                       \ rS rSrSrSrg)r{  i  zWorkloadCertificateFeatureState describes the state of the workload
certificate feature. This is required since FeatureStateDetails requires a
state.
r   Nr   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)r+  i  a  WorkloadCertificateMembershipSpec contains the membership-specific input
for WorkloadCertificate feature.

Enums:
  CertificateManagementValueValuesEnum: Specifies workload certificate
    management.

Fields:
  certificateManagement: Specifies workload certificate management.
c                   $    \ rS rSrSrSrSrSrSrg)FWorkloadCertificateMembershipSpec.CertificateManagementValueValuesEnumi  zSpecifies workload certificate management.

Values:
  CERTIFICATE_MANAGEMENT_UNSPECIFIED: Disable workload certificate
    feature.
  DISABLED: Disable workload certificate feature.
  ENABLED: Enable workload certificate feature.
r   r   r#   r   N)	r   r   r   r   r   "CERTIFICATE_MANAGEMENT_UNSPECIFIEDr  r^  r   r   r   r   $CertificateManagementValueValuesEnumr0    s     *+&HGr   r2  r   r   N)r   r   r   r   r   r   r2   r2  r6   certificateManagementr   r   r   r   r+  r+    s.    	Y^^  $--.TVWXr   r+  r~  inr  z$.xgafvr  1r  2r  zoptions.requestedPolicyVersionN)r   
__future__r   apitools.base.protorpcliter   r   apitools.base.pyr   r   packager   r	   r   r   r    r9   rL   rW   r[   r;   rh   rl   ry   r   r   r   r   r   r   r   r   r   r&  r-  r;  rG  rm  r.  r  r  r  r  r  r  r  r  r  r  r  r  r<  r  r  r   r	  r:  r<  r  rf  r  r  r  rp  r  r  rO  r  r  r=  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r<   r  r  r  r  r  rq  r)  r-  r/  r7  r  rr  rG  rJ  r=   rS  rW  r[  r_  ra  rX  rr  r  r  r+  r  r  rs  r  rt  r  ru  r  rv  r  r>  r?   r  r\  r  r0  r  r  r  r  r  r  rw  r&  r  r<  r  r4  r1  rV  r  rx  r  rd  r  rw  r  rB   rL  rM  r  ry  r  r  r  rz  r  r  r  r  r   r  r   r  r  r  r  r  r  rN  r  r{  r+  AddCustomJsonFieldMappingAddCustomJsonEnumMappingr  r   r   r   <module>r=     s  
 ' < % ( .)"3"3 .C9#4#4 C%)## %:!=Y&& !=H7"" 7.K)"3"3 K<I-- Y.. 'I%% '6&Y&& &=I%% =>,i'' ,V"i V"r?	)) ?=Y.. =G9#4#4 GI$5$5 0K	)) 0Kf4JI-- 4Jn%!2!2 %<n?	!! n?b$J)"3"3 $JNM9#4#4 M:'*"" '*Tu;	 1 1 u;p*i'' *i;i'' i;X$	)) $8+	)) +$;9Y.. ;9|^%9,, ^%B$Y&& $6'Y.. '6#)## #!=	)) !=H(9)++ (9V	/Y.. 	/i// 'Y.. '$1** 1"I (I%% ( !#9 !#Ha`i a`H	)9$$ 	)[9I%% [9|FK9$$ FKRPb)++ Pbf
Gy00 
GD):): D@
=I$5$5 
=
NY%6%6 
N	MY%6%6 	MJ	(9(9 J	FY 	FCS	 1 1 CSL")++ "+	!! +:59J9J 54I9J9J I Uy?P?P U 1	(9(9 139J9J 319J9J 13i6G6G 3  3y7H7H  3F(	8I8I ('):): '6
1Y5F5F 
11Y5F5F 11)2C2C 1393D3D 30&9$$ &@39,, @3F0%i'' 0%f))## ),%y(( %=I-- =Y.. &	 1 1 &15):): 15h	Dy00 	D	!!2!2 	!)B!2!2 )BX9)"3"3 9@-Y.. -*9$$ *1"" 1(B9,, B
+I-- 
+8Y.. 8$$I-- $(
EY.. 
EM"y   M"`>	!! >DI%% D
O9$$ 
O1%y(( 1%h)9y(( )9X)++ d9,, d.Y%6%6 .Bi&7&7 i.?.? y/@/@ BJI$5$5 BJJ+Y%6%6 +5y'8'8 5+	!! +*&)"" &)RI9Y&& I9Xi8	!! i8X"	)) "4%I%% %BSGY SGl+G	)) +G\-E** -E`(y(( (D!+y'8'8 !+H#F)"3"3 #FLp99#4#4 p9fb7	 1 1 b7J%Y%6%6 %9	 1 1 9:W!2!2 W:Wy'8'8 W:AI-- A%i// %0)*;*; 09+<+< :"	!! :"z	$9$$ 	$79,, 77I%% 72289 28jI("" I(X"9$$ "(	M9,, 	M)"3"3 9#4#4 3:!2!2 3:l+Y%6%6 +D;IY.. ;I|1Ci// 1ChnC	 1 1 nCb()++ ("&I-- &"<.i// <.~ )Y  )F	%I%% 	%M	!! M1'	!! 1'hGI-- G8
8	 1 1 
88!2!2 8#"" # )9 )*,"" ,<AQY%6%6 AQHi&7&7 Y	(9(9 Y8 	 " "%  " "Z4  ! !114>  ! !114>  " "68XZz|r   