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

    )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       Slib/googlecloudsdk/generated_clients/apis/gkehub/v1alpha/gkehub_v1alpha_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5      rSrg)ApplianceCluster   a3  ApplianceCluster contains information specific to GDC Edge Appliance
Clusters.

Fields:
  resourceLink: Immutable. Self-link of the Google Cloud resource for the
    Appliance Cluster. For example:
    //transferappliance.googleapis.com/projects/my-project/locations/us-
    west1-a/appliances/my-appliance
r   r   N)	r   r   r   r   r   r   StringFieldresourceLinkr   r   r   r   r   r      s     &&q),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   auditLogConfigsr    servicer   r   r   r   r#   r#   -   s.    0 **+;QN/!!!$'r   r#   c                       \ rS rSrSr " S S\R                  5      r\R                  " SSS9r	\R                  " S5      r\R                  " SS	5      rS
rg)r%   J   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.LogTypeValueValuesEnum[   a  The log type that this config enables.

Values:
  LOG_TYPE_UNSPECIFIED: Default case. Should never be this.
  ADMIN_READ: Admin reads. Example: CloudIAM getIamPolicy
  DATA_WRITE: Data writes. Example: CloudSQL Users create
  DATA_READ: Data reads. Example: CloudSQL Users list
r   r   r(      r   N)
r   r   r   r   r   LOG_TYPE_UNSPECIFIED
ADMIN_READ
DATA_WRITE	DATA_READr   r   r   r   LogTypeValueValuesEnumr.   [   s     JJIr   r5   r   Tr&   r(   r0   r   N)r   r   r   r   r   r   Enumr5   r    exemptedMembersBooleanFieldignoreChildExemptions	EnumFieldlogTyper   r   r   r   r%   r%   J   sO     y~~  ))!d;/#003 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\R                  " S5      rS	rg
)	Authorityn   ai  Authority encodes how Google will recognize identities from this
Membership. See the workload identity documentation for more details:
https://cloud.google.com/kubernetes-engine/docs/how-to/workload-identity

Fields:
  identityProvider: Output only. An identity provider that reflects the
    `issuer` in the workload identity pool.
  issuer: Optional. A JSON Web Token (JWT) issuer URI. `issuer` must start
    with `https://` and be a valid URL with length <2000 characters, it must
    use `location` rather than `zone` for GKE clusters. If set, then Google
    will allow valid OIDC tokens from this issuer to authenticate within the
    workload_identity_pool. OIDC discovery will be performed on this URI to
    validate tokens from the issuer. Clearing `issuer` disables Workload
    Identity. `issuer` cannot be directly modified; it must be cleared (and
    Workload Identity disabled) before using a new issuer (and re-enabling
    Workload Identity).
  oidcJwks: Optional. OIDC verification keys for this Membership in JWKS
    format (RFC 7517). When this field is set, OIDC discovery will NOT be
    performed on `issuer`, and instead OIDC tokens will be validated using
    this field.
  scopeTenancyIdentityProvider: Optional. Output only. The identity provider
    for the scope-tenancy workload identity pool.
  scopeTenancyWorkloadIdentityPool: Optional. Output only. The name of the
    scope-tenancy workload identity pool. This pool is set in the fleet-
    level feature.
  workloadIdentityPool: Output only. The name of the workload identity pool
    in which `issuer` will be recognized. There is a single Workload
    Identity Pool per Hub that is shared between all Memberships that belong
    to that Hub. For a Hub hosted in {PROJECT_ID}, the workload pool format
    is `{PROJECT_ID}.hub.id.goog`, although this is subject to change in
    newer versions of this API.
r   r(   r0            r   N)r   r   r   r   r   r   r    identityProviderissuer
BytesFieldoidcJwksscopeTenancyIdentityProvider scopeTenancyWorkloadIdentityPoolworkloadIdentityPoolr   r   r   r   r=   r=   n   sn    B **1-  #&!!!$(!*!6!6q!9%.%:%:1%=""..q1r   r=   c                   h    \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	Sr
g)AuthorizationLoggingOptions   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(   r0   r?   r   Nr   r   r   r   r   PERMISSION_TYPE_UNSPECIFIEDr2   ADMIN_WRITEr4   r3   r   r   r   r   PermissionTypeValueValuesEnumrM      s#     #$JKIJr   rR   r   r   N)r   r   r   r   r   r   r6   rR   r:   permissionTyper   r   r   r   rJ   rJ      s,    inn   &&'FJ.r   rJ   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)BinaryAuthorizationConfig   ao  BinaryAuthorizationConfig defines the fleet level configuration of
binary authorization feature.

Enums:
  EvaluationModeValueValuesEnum: Optional. Mode of operation for binauthz
    policy evaluation.

Fields:
  evaluationMode: Optional. Mode of operation for binauthz policy
    evaluation.
  policyBindings: Optional. Binauthz policies that apply to this cluster.
c                   $    \ rS rSrSrSrSrSrSrg)7BinaryAuthorizationConfig.EvaluationModeValueValuesEnum   zOptional. Mode of operation for binauthz policy evaluation.

Values:
  EVALUATION_MODE_UNSPECIFIED: Default value
  DISABLED: Disable BinaryAuthorization
  POLICY_BINDINGS: Use Binary Authorization with the policies specified in
    policy_bindings.
r   r   r(   r   N)	r   r   r   r   r   EVALUATION_MODE_UNSPECIFIEDDISABLEDPOLICY_BINDINGSr   r   r   r   EvaluationModeValueValuesEnumrX      s     #$HOr   r]   r   PolicyBindingr(   Tr&   r   N)r   r   r   r   r   r   r6   r]   r:   evaluationModer   policyBindingsr   r   r   r   rU   rU      s@    inn  &&'FJ.))/1tL.r   rU   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(   r0   Tr&   r?   r   N)r   r   r   r   r   r   r    	bindingIdr   	conditionmembersroler   r   r   r   rb   rb      sO    Pd ##A&)$$VQ/)!!!d3'			q	!$r   rb   c                       \ rS rSrSrSrg)CancelOperationRequesti.  z3The request message for Operations.CancelOperation.r   Nr   r   r   r   rj   rj   .  s    <r   rj   c                       \ rS rSrSrSrg)CancelRolloutRequesti2  z)Request message for cancelling a rollout.r   Nr   r   r   r   rl   rl   2  s    2r   rl   c                   :    \ rS rSrSr\R                  " SSS9rSrg)CloudAuditLoggingFeatureSpeci6  a  **Cloud Audit Logging**: 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   rn   rn   6  s    	  )44QFr   rn   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)CloudAuditOptionsiE  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.LogNameValueValuesEnumiU  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   LogNameValueValuesEnumrs   U  s     NKr   rw   c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
/CloudAuditOptions.PermissionTypeValueValuesEnumia  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(   r0   r?   r   NrO   r   r   r   rR   ry   a  s#    
 #$JKIJr   rR   rJ   r   r(   r0   r   N)r   r   r   r   r   r   r6   rw   rR   r   authorizationLoggingOptionsr:   logNamerS   r   r   r   r   rq   rq   E  sd    
y~~ 
inn $ !* 6 67TVW X 8!<'&&'FJ.r   rq   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)	CloudBuildMembershipSpecix  ae  **Cloud Build**: 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)6CloudBuildMembershipSpec.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   r6   r   r:   securityPolicyr    versionr   r   r   r   r}   r}   x  s<    
inn  &&'FJ.!!!$'r   r}   c                   <    \ rS rSrSr\R                  " S5      rSrg)ClusterSelectori  zSelector for clusters.

Fields:
  labelSelector: The label selector must be a valid CEL (go/cel) expression
    which evaluates resource.labels.
r   r   N)	r   r   r   r   r   r   r    labelSelectorr   r   r   r   r   r     s     ''*-r   r   c                   B   \ rS rSrSr " S S\R                  5      r\R                  " S5      r	\R                  " S5      r
\R                  " S5      r\R                  " S5      r\R                  " SS	5      r\R                  " S
\R                   R"                  S9rSrg)ClusterStatusi  a  Metadata about the status of a clusters involved in the Rollout.

Enums:
  StateValueValuesEnum: Optional. Output only. The high-level, machine-
    readable status of this Rollout for the cluster.

Fields:
  lastUpdateTime: Optional. Output only. The time this status and any
    related Rollout-specific details for the cluster were updated.
  membership: Output only. The name of the fleet Membership resource
    associated to the updated cluster. Membership names are formatted as
    projects//locations//memberships/.
  operation: Optional. Output only. The operation resource name performing
    the mutation.
  reason: Optional. Output only. A human-readable description of the current
    status.
  state: Optional. Output only. The high-level, machine-readable status of
    this Rollout for the cluster.
  waveAssignment: Output only. The wave assignment of this cluster in this
    rollout (between 1 and 5).
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)"ClusterStatus.StateValueValuesEnumi  a  Optional. Output only. The high-level, machine-readable status of this
Rollout for the cluster.

Values:
  STATE_UNSPECIFIED: Unspecified state.
  PENDING: The Rollout is pending for the cluster.
  RUNNING: The Rollout is running for the cluster.
  FAILED: The Rollout failed for the cluster.
  SUCCEEDED: The Rollout succeeded for the cluster.
  PAUSED: The Rollout is paused for the cluster.
  REMOVED: The cluster was removed from the Rollout.
  INELIGIBLE: The cluster is ineligible for the Rollout.
r   r   r(   r0   r?   r@   rA      r   Nr   r   r   r   r   STATE_UNSPECIFIEDPENDINGRUNNINGFAILED	SUCCEEDEDPAUSEDREMOVED
INELIGIBLEr   r   r   r   StateValueValuesEnumr     2     GGFIFGJr   r   r   r(   r0   r?   r@   rA   variantr   N)r   r   r   r   r   r   r6   r   r    lastUpdateTime
membership	operationreasonr:   stateIntegerFieldVariantINT32waveAssignmentr   r   r   r   r   r     s    ,Y^^ . ((+.$$Q'*##A&)  #&


4a
8%))!Y5F5F5L5LM.r   r   c                       \ rS rSrSr\R                  " SSSS9r\R                  " SS5      r\R                  " S	SS9r
S
rg)ClusterUpgradeFleetSpeci  ak  **ClusterUpgrade**: The configuration for the fleet-level ClusterUpgrade
feature.

Fields:
  gkeUpgradeOverrides: Allow users to override some properties of each GKE
    upgrade.
  postConditions: Required. Post conditions to evaluate to mark an upgrade
    COMPLETE. Required.
  upstreamFleets: This fleet consumes upgrades that have COMPLETE status
    code in the upstream fleets. See UpgradeStatus.Code for code
    definitions. The fleet name should be either fleet project number or id.
    This is defined as repeated for future proof reasons. Initial
    implementation will enforce at most one upstream fleet.
 ClusterUpgradeGKEUpgradeOverrider   Tr&   ClusterUpgradePostConditionsr(   r0   r   N)r   r   r   r   r   r   r   gkeUpgradeOverridespostConditionsr    upstreamFleetsr   r   r   r   r   r     sF     "../QST_cd))*H!L.((T:.r   r   c                       \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " SSS9r\R                  " S	S
5      r\R                  " SS5      rSrg)ClusterUpgradeFleetStatei  aN  **ClusterUpgrade**: The state for the fleet-level ClusterUpgrade
feature.

Messages:
  IgnoredValue: A list of memberships ignored by the feature. For example,
    manually upgraded clusters can be ignored if they are newer than the
    default versions of its release channel. The membership resource is in
    the format: `projects/{p}/locations/{l}/membership/{m}`.

Fields:
  downstreamFleets: This fleets whose upstream_fleets contain the current
    fleet. The fleet name should be either fleet project number or id.
  gkeState: Feature state for GKE clusters.
  ignored: A list of memberships ignored by the feature. For example,
    manually upgraded clusters can be ignored if they are newer than the
    default versions of its release channel. The membership resource is in
    the format: `projects/{p}/locations/{l}/membership/{m}`.
additionalPropertiesc                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
%ClusterUpgradeFleetState.IgnoredValuei     A list of memberships ignored by the feature. For example, manually
upgraded clusters can be ignored if they are newer than the default
versions of its release channel. The membership resource is in the format:
`projects/{p}/locations/{l}/membership/{m}`.

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

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

Fields:
  key: Name of the additional property.
  value: A ClusterUpgradeIgnoredMembership attribute.
r   ClusterUpgradeIgnoredMembershipr(   r   Nr   r   r   r   r   r   r    keyr   valuer   r   r   r   AdditionalPropertyr     ,    
 !!!$c$$%FJer   r   r   Tr&   r   Nr   r   r   r   r   r   Messager   r   r   r   r   r   r   IgnoredValuer      4    
	KY.. 	K %112FTXYr   r   r   Tr&   $ClusterUpgradeGKEUpgradeFeatureStater(   r0   r   N)r   r   r   r   r   r   MapUnrecognizedFieldsr   r   r   r    downstreamFleetsr   gkeStateignoredr   r   r   r   r   r     sq    & !!"89ZY&& Z :Z4 **1t<##$JAN("">15'r   r   c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)ClusterUpgradeGKEUpgradei   aT  GKEUpgrade represents a GKE provided upgrade, e.g., control plane
upgrade.

Fields:
  name: Name of the upgrade, e.g., "k8s_control_plane". It should be a valid
    upgrade name. It must not exceet 99 characters.
  version: Version of the upgrade, e.g., "1.22.1-gke.100". It should be a
    valid version. It must not exceet 99 characters.
r   r(   r   N)
r   r   r   r   r   r   r    namer   r   r   r   r   r   r      s)     
		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)	(ClusterUpgradeGKEUpgradeFeatureConditioni/  aY  GKEUpgradeFeatureCondition describes the condition of the feature for
GKE clusters at a certain point of time.

Fields:
  reason: Reason why the feature is in this status.
  status: Status of the condition, one of True, False, Unknown.
  type: Type of the condition, for example, "ready".
  updateTime: Last timestamp the condition was updated.
r   r(   r0   r?   r   N)r   r   r   r   r   r   r    r   statustype
updateTimer   r   r   r   r   r   /  sI       #&  #&			q	!$$$Q'*r   r   c                   `    \ rS rSrSr\R                  " SSSS9r\R                  " SSSS9rS	r	g
)r   i@  zGKEUpgradeFeatureState contains feature states for GKE clusters in the
scope.

Fields:
  conditions: Current conditions of the feature.
  upgradeState: Upgrade state. It will eventually replace `state`.
r   r   Tr&   ClusterUpgradeGKEUpgradeStater(   r   N)
r   r   r   r   r   r   r   
conditionsupgradeStater   r   r   r   r   r   @  s6     %%&PRS^bc*''(GUYZ,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   iM  a:  Properties of a GKE upgrade that can be overridden by the user. For
example, a user can skip soaking by overriding the soaking to 0.

Fields:
  postConditions: Required. Post conditions to override for the specified
    upgrade (name + version). Required.
  upgrade: Required. Which upgrade to override. Required.
r   r   r   r(   r   N)
r   r   r   r   r   r   r   r   upgrader   r   r   r   r   r   M  s/     ))*H!L.""#=q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\R                  " SS5      r\R                  " S	S
5      rSrg)r   i[  a  GKEUpgradeState is a GKEUpgrade and its state at the scope and fleet
level.

Messages:
  StatsValue: Number of GKE clusters in each status code.

Fields:
  stats: Number of GKE clusters in each status code.
  status: Status of the upgrade.
  upgrade: Which upgrade to track the state.
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	)
(ClusterUpgradeGKEUpgradeState.StatsValueih  zNumber of GKE clusters in each status code.

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

Fields:
  additionalProperties: Additional properties of type StatsValue
c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      r	Sr
g);ClusterUpgradeGKEUpgradeState.StatsValue.AdditionalPropertyis  z~An additional property for a StatsValue 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   s  s)    
 !!!$c$$Q'er   r   r   Tr&   r   Nr   r   r   r   
StatsValuer   h  s2    	(Y.. 	( %112FTXYr   r   r   ClusterUpgradeUpgradeStatusr(   r   r0   r   N)r   r   r   r   r   r   r   r   r   r   r   statsr   r   r   r   r   r   r   r   [  sq    
 !!"89Z9$$ Z :Z. 
 
 q
1%!!"?C&""#=qA'r   r   c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)r   i  a  IgnoredMembership represents a membership ignored by the feature. A
membership can be ignored because it was manually upgraded to a newer
version than RC default.

Fields:
  ignoredTime: Time when the membership was first set to ignored.
  reason: Reason why the membership is ignored.
r   r(   r   N)
r   r   r   r   r   r   r    ignoredTimer   r   r   r   r   r   r     s)     %%a(+  #&r   r   c                   d    \ rS rSrSr\R                  " SS5      r\R                  " SS5      rSr	g)	'ClusterUpgradeMembershipGKEUpgradeStatei  zScopeGKEUpgradeState is a GKEUpgrade and its state per-membership.

Fields:
  status: Status of the upgrade.
  upgrade: Which upgrade to track the state.
r   r   r   r(   r   N)
r   r   r   r   r   r   r   r   r   r   r   r   r   r   r     s/     !!"?C&""#=qA'r   r   c                       \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	\R                  " SS	SS9r
S
rg)ClusterUpgradeMembershipStatei  a  Per-membership state for this feature.

Fields:
  ignored: Whether this membership is ignored by the feature. For example,
    manually upgraded clusters can be ignored if they are newer than the
    default versions of its release channel.
  scopes: Fully qualified scope names that this clusters is bound to which
    also have rollout sequencing enabled.
  upgrades: Actual upgrade state against desired.
r   r   r(   Tr&   r   r0   r   N)r   r   r   r   r   r   r   r   r    scopesupgradesr   r   r   r   r   r     sD    	 ""#DaH'  T2&##$Mq[_`(r   r   c                   <    \ rS rSrSr\R                  " S5      rSrg)r   i  zPost conditional checks after an upgrade has been applied on all
eligible clusters.

Fields:
  soaking: Required. Amount of time to "soak" after a rollout has been
    finished before marking it COMPLETE. Cannot exceed 30 days. Required.
r   r   N)	r   r   r   r   r   r   r    soakingr   r   r   r   r   r     s     !!!$'r   r   c                       \ rS rSrSr\R                  " SSSS9r\R                  " SS5      r\R                  " S	SS9r
S
rg)ClusterUpgradeScopeSpeci  a  **ClusterUpgrade**: The configuration for the scope-level ClusterUpgrade
feature.

Fields:
  gkeUpgradeOverrides: Allow users to override some properties of each GKE
    upgrade.
  postConditions: Required. Post conditions to evaluate to mark an upgrade
    COMPLETE. Required.
  upstreamScopes: This scope consumes upgrades that have COMPLETE status
    code in the upstream scopes. See UpgradeStatus.Code for code
    definitions. The scope name should be in the form:
    `projects/{p}/locations/global/scopes/{s}` Where {p} is the project, {s}
    is a valid Scope in this project. {p} WILL match the Feature's project.
    This is defined as repeated for future proof reasons. Initial
    implementation will enforce at most one upstream scope.
r   r   Tr&   r   r(   r0   r   N)r   r   r   r   r   r   r   r   r   r    upstreamScopesr   r   r   r   r   r     sF    " "../QST_cd))*H!L.((T:.r   r   c                       \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " SSS9r\R                  " S	S
5      r\R                  " SS5      rSrg)ClusterUpgradeScopeStatei  a  **ClusterUpgrade**: The state for the scope-level ClusterUpgrade
feature.

Messages:
  IgnoredValue: A list of memberships ignored by the feature. For example,
    manually upgraded clusters can be ignored if they are newer than the
    default versions of its release channel. The membership resource is in
    the format: `projects/{p}/locations/{l}/membership/{m}`.

Fields:
  downstreamScopes: This scopes whose upstream_scopes contain the current
    scope. The scope name should be in the form:
    `projects/{p}/locations/gloobal/scopes/{s}` Where {p} is the project,
    {s} is a valid Scope in this project. {p} WILL match the Feature's
    project.
  gkeState: Feature state for GKE clusters.
  ignored: A list of memberships ignored by the feature. For example,
    manually upgraded clusters can be ignored if they are newer than the
    default versions of its release channel. The membership resource is in
    the format: `projects/{p}/locations/{l}/membership/{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	)
%ClusterUpgradeScopeState.IgnoredValuei  r   c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)8ClusterUpgradeScopeState.IgnoredValue.AdditionalPropertyi  r   r   r   r(   r   Nr   r   r   r   r   r     r   r   r   r   Tr&   r   Nr   r   r   r   r   r     r   r   r   r   Tr&   r   r(   r0   r   N)r   r   r   r   r   r   r   r   r   r   r    downstreamScopesr   r   r   r   r   r   r   r   r     sq    , !!"89ZY&& Z :Z4 **1t<##$JAN("">15'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	5      r\R                  " S
5      rSrg)r   i
  aB  UpgradeStatus provides status information for each upgrade.

Enums:
  CodeValueValuesEnum: Status code of the upgrade.
  TypeValueValuesEnum: Type of the status.

Fields:
  code: Status code of the upgrade.
  reason: Reason for this status.
  type: Type of the status.
  updateTime: Last timestamp the status was updated.
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)/ClusterUpgradeUpgradeStatus.CodeValueValuesEnumi  aq  Status code of the upgrade.

Values:
  CODE_UNSPECIFIED: Required by https://linter.aip.dev/126/unspecified.
  INELIGIBLE: The upgrade is ineligible. At the scope level, this means
    the upgrade is ineligible for all the clusters in the scope.
  PENDING: The upgrade is pending. At the scope level, this means the
    upgrade is pending for all the clusters in the scope.
  IN_PROGRESS: The upgrade is in progress. At the scope level, this means
    the upgrade is in progress for at least one cluster in the scope.
  SOAKING: The upgrade has finished and is soaking until the soaking time
    is up. At the scope level, this means at least one cluster is in
    soaking while the rest are either soaking or complete.
  FORCED_SOAKING: A cluster will be forced to enter soaking if an upgrade
    doesn't finish within a certain limit, despite it's actual status.
  COMPLETE: The upgrade has passed all post conditions (soaking). At the
    scope level, this means all eligible clusters are in COMPLETE status.
  PAUSED: The upgrade is paused. At the scope level, this means the
    upgrade is paused for all the clusters in the scope.
r   r   r(   r0   r?   r@   rA   r   r   N)r   r   r   r   r   CODE_UNSPECIFIEDr   r   IN_PROGRESSSOAKINGFORCED_SOAKINGCOMPLETEr   r   r   r   r   CodeValueValuesEnumr     s2    ( JGKGNHFr   r   c                   4    \ rS rSrSrSrSrSrSrSr	Sr
S	rS
rg)/ClusterUpgradeUpgradeStatus.TypeValueValuesEnumi6  ar  Type of the status.

Values:
  TYPE_UNSPECIFIED: Required by https://linter.aip.dev/126/unspecified.
  DISRUPTION_BUDGET: The upgrade is PAUSED due to the cluster's disruption
    budget. Cluster is out of disruption budget. Once the cluster is back
    in budget, the upgrade will resume.
  MAINTENANCE_POLICY: The upgrade is PAUSED due to the cluster's
    maintenance policy. The upgrade will resume once cluster's maintenance
    window is open and/or maintenance exclusion is over.
  SYSTEM_CONFIG: The upgrade is PAUSED due to the system config.
  CLUSTER_STATUS: The upgrade is INELIGIBLE due to the cluster's status.
  INCOMPATIBLE_VERSION: The upgrade is INELIGIBLE due to the cluster's
    current version being incompatible with the target version.
  DISABLED_BY_USER: The upgrade is INELIGIBLE due to the user disabling
    auto upgrades. Applies to node upgrades only.
r   r   r(   r0   r?   r@   rA   r   N)r   r   r   r   r   TYPE_UNSPECIFIEDDISRUPTION_BUDGETMAINTENANCE_POLICYSYSTEM_CONFIGCLUSTER_STATUSINCOMPATIBLE_VERSIONDISABLED_BY_USERr   r   r   r   TypeValueValuesEnumr   6  s1    " MNr   r   r   r(   r0   r?   r   N)r   r   r   r   r   r   r6   r   r   r:   coder    r   r   r   r   r   r   r   r   r   
  so    INN <INN 4 
		2A	6$  #&			2A	6$$$Q'*r   r   c                      \ rS rSrSr\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r	\R                  " S	S
5      r
\R                  " SS5      r\R                  " S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)CommonFeatureSpeciV  a   CommonFeatureSpec contains Fleet-wide configuration information

Fields:
  appdevexperience: Appdevexperience specific spec.
  cloudauditlogging: Cloud Audit Logging-specific spec.
  clusterupgrade: ClusterUpgrade (fleet-based) feature spec.
  dataplanev2: DataplaneV2 feature spec.
  fleetobservability: FleetObservability feature spec.
  helloworld: Hello World-specific spec.
  mesh: Servicemesh feature spec.
  multiclusteringress: Multicluster Ingress-specific spec.
  namespaceactuation: Namespace Actuation feature spec
  rbacrolebindingactuation: RBAC Role Binding Actuation feature spec
  workloadcertificate: Workload Certificate spec.
  workloadidentity: Workload Identity feature spec.
  workloadmigration: The specification for WorkloadMigration feature.
r	   r   rn   r(   r   r0   DataplaneV2FeatureSpecr?   FleetObservabilityFeatureSpecr@   HelloWorldFeatureSpecrA   ServiceMeshFeatureSpecr   MultiClusterIngressFeatureSpec   NamespaceActuationFeatureSpec	   #RBACRoleBindingActuationFeatureSpec
   FeatureSpec   WorkloadIdentityFeatureSpec   WorkloadMigrationFeatureSpec   r   N)r   r   r   r   r   r   r   appdevexperiencecloudauditloggingclusterupgradedataplanev2fleetobservability
helloworldmeshmulticlusteringressnamespaceactuationrbacrolebindingactuationworkloadcertificateworkloadidentityworkloadmigrationr   r   r   r   r  r  V  s
   $ ++,I1M,,-KQO))*CQG.&&'?C+ --.MqQ%%&=qA*			 8!	<$!../OQRS --.MqQ&334Y[]^!..}bA++,I2N,,-KRPr   r  c                   n   \ rS rSrSr\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r	\R                  " S	S
5      r
\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      rSrg)CommonFeatureStateix  aB  CommonFeatureState contains Fleet-wide Feature status information.

Fields:
  appdevexperience: Appdevexperience specific state.
  clusterupgrade: ClusterUpgrade fleet-level state.
  fleetobservability: FleetObservability feature state.
  helloworld: Hello World-specific state.
  namespaceactuation: Namespace Actuation feature state.
  rbacrolebindingactuation: RBAC Role Binding Actuation feature state
  servicemesh: Service Mesh-specific state.
  state: Output only. The "running state" of the Feature in this Fleet.
  workloadidentity: WorkloadIdentity fleet-level state.
r   r   r   r(   FleetObservabilityFeatureStater0   HelloWorldFeatureStater?   NamespaceActuationFeatureStater@   $RBACRoleBindingActuationFeatureStaterA   ServiceMeshFeatureStater   FeatureStater  WorkloadIdentityFeatureStater
  r   N)r   r   r   r   r   r   r   r  r  r  r  r  r  servicemeshr   r  r   r   r   r   r!  r!  x  s     ++,JAN))*DaH. --.NPQR%%&>B* --.NPQR&334Z\]^&&'@!D+

 
 
3%++,JANr   r!  c                       \ rS rSrSr\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r	\R                  " S	S
5      r
\R                  " SS5      rSrg)"CommonFleetDefaultMemberConfigSpeci  aY  CommonFleetDefaultMemberConfigSpec contains default configuration
information for memberships of a fleet

Fields:
  configmanagement: Config Management-specific spec.
  helloworld: Hello World-specific spec.
  identityservice: Identity Service-specific spec.
  mesh: Anthos Service Mesh-specific spec
  policycontroller: Policy Controller spec.
ConfigManagementMembershipSpecr   HelloWorldMembershipSpecr(   IdentityServiceMembershipSpecr0   ServiceMeshMembershipSpecr?   PolicyControllerMembershipSpecr@   r   N)r   r   r   r   r   r   r   configmanagementr  identityservicer  policycontrollerr   r   r   r   r+  r+    sj    	 ++,LaP%%&@!D***+JAN/			 ;Q	?$++,LaP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)CompliancePostureConfigi  a@  CompliancePostureConfig defines the settings needed to enable/disable
features for the Compliance Posture.

Enums:
  ModeValueValuesEnum: Defines the enablement mode for Compliance Posture.

Fields:
  complianceStandards: List of enabled compliance standards.
  mode: Defines the enablement mode for Compliance Posture.
c                   $    \ rS rSrSrSrSrSrSrg)+CompliancePostureConfig.ModeValueValuesEnumi  zDefines the enablement mode for Compliance Posture.

Values:
  MODE_UNSPECIFIED: Default value not specified.
  DISABLED: Disables Compliance Posture features on the cluster.
  ENABLED: Enables Compliance Posture features on the cluster.
r   r   r(   r   N)	r   r   r   r   r   MODE_UNSPECIFIEDr[   ENABLEDr   r   r   r   ModeValueValuesEnumr7    s     HGr   r:  ComplianceStandardr   Tr&   r(   r   N)r   r   r   r   r   r   r6   r:  r   complianceStandardsr:   moder   r   r   r   r5  r5    sC    	
INN 
 "../CQQUV			2A	6$r   r5  c                   <    \ rS rSrSr\R                  " S5      rSrg)r;  i  zSA ComplianceStandard object.

Fields:
  standard: Name of the compliance standard.
r   r   N)	r   r   r   r   r   r   r    standardr   r   r   r   r;  r;    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)	Conditioni  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)Condition.IamValueValuesEnumi  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(   r0   r?   r@   rA   r   r   N)r   r   r   r   r   NO_ATTR	AUTHORITYATTRIBUTIONSECURITY_REALMAPPROVERJUSTIFICATION_TYPECREDENTIALS_TYPECREDS_ASSERTIONr   r   r   r   IamValueValuesEnumrC    s4    :v GIKNHOr   rL  c                   0    \ rS rSrSrSrSrSrSrSr	Sr
S	rg
)Condition.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(   r0   r?   r@   r   N)r   r   r   r   r   NO_OPEQUALS
NOT_EQUALSINNOT_IN
DISCHARGEDr   r   r   r   OpValueValuesEnumrN  "  s'     EFJ	
BFJr   rU  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
Condition.SysValueValuesEnumi6  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(   r0   r?   r   N)r   r   r   r   r   rD  REGIONSERVICENAMEIPr   r   r   r   SysValueValuesEnumrW  6  s"    	 GFGD	
Br   r\  r   r(   r0   r?   r@   Tr&   r   N)r   r   r   r   r   r   r6   rL  rU  r\  r:   iamopr    svcsysvaluesr   r   r   r   rA  rA    s    "C9>> CJ).. (9>> " 	0!4#.2"a #0!4#  T2&r   rA  c                   $   \ rS rSrSr " S S\R                  5      r " S S\R                  5      r\R                  " S5      r
\R                  " S5      r\R                  " S	5      r\R                  " SS
5      r\R                  " SS5      rSrg)ConfigDeliveryArgoCDConditioniN  a  Condition contains details for one aspect of the current state of the
reconciliation object.

Enums:
  StatusValueValuesEnum: status of the condition, one of True, False,
    Unknown.
  TypeValueValuesEnum: type of condition in CamelCase.

Fields:
  lastTransitionTime: lastTransitionTime is the last time the condition
    transitioned from one status to another
  message: message is a human readable message indicating details about the
    transition. This may be an empty string.
  reason: reason contains a programmatic identifier indicating the reason
    for the condition's last transition.
  status: status of the condition, one of True, False, Unknown.
  type: type of condition in CamelCase.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	3ConfigDeliveryArgoCDCondition.StatusValueValuesEnumib  aw  status of the condition, one of True, False, Unknown.

Values:
  CONDITION_STATUS_UNSPECIFIED: CONDITION_STATUS_UNSPECIFIED is the
    default unspecified conditionStatus.
  TRUE: TRUE means a resource is in the condition.
  FALSE: FALSE means a resource is not in the condition.
  UNKNOWN: UNKNOWN means kubernetes can't decide if a resource is in the
    condition or not.
r   r   r(   r0   r   N)
r   r   r   r   r   CONDITION_STATUS_UNSPECIFIEDTRUEFALSEUNKNOWNr   r   r   r   StatusValueValuesEnumre  b  s    	 $% DEGr   rj  c                        \ rS rSrSrSrSrSrg)1ConfigDeliveryArgoCDCondition.TypeValueValuesEnumir  a  type of condition in CamelCase.

Values:
  CONDITION_TYPE_UNSPECIFIED: CONDITION_TYPE_UNSPECIFIED is the default
    unspecified conditionType.
  READY: READY indicates the type of the configdeliveryargocd' status
    condtion is "READY". This is a normally used term in k8s which used as
    a specific "conditionType". The "conditionStatus" tells the value of
    "READY" (e.g. conditionStatus=true means not ready).
r   r   r   N)r   r   r   r   r   CONDITION_TYPE_UNSPECIFIEDREADYr   r   r   r   r   rl  r  s    	 "#Er   r   r   r(   r0   r?   r@   r   N)r   r   r   r   r   r   r6   rj  r   r    lastTransitionTimemessager   r:   r   r   r   r   r   r   rc  rc  N  s    &inn  INN  !,,Q/!!!$'  #&6:&			2A	6$r   rc  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
)$ConfigDeliveryArgoCDDeclarativeStatei  a  DeclarativeState summaries the state of all the deployable manifests.

Fields:
  conditions: conditions provides a standard mechanism for higher-level
    status reporting from the moss reconciler.
  healthy: healthy tells whether the current state is healthy or not.
  version: version is the current in-use ArgoCD version. Users can only
    specify the channel and the margo/populas operator will decide which
    version is actually being used.
rc  r   Tr&   r(   r0   r   N)r   r   r   r   r   r   r   r   r8   healthyr    r   r   r   r   r   rr  rr    s?    	 %%&EqSWX*""1%'!!!$'r   rr  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)	"ConfigDeliveryArgoCDMembershipSpeci  a  MembershipSpec defines the ConfigDeliveryArgoCD Feature specification.

Enums:
  ChannelValueValuesEnum: Channel specifies a channel that can be used to
    resolve a specific addon. Margo will use the same release channel as the
    current cluster. It is not being used. Hidden from customers.

Fields:
  channel: Channel specifies a channel that can be used to resolve a
    specific addon. Margo will use the same release channel as the current
    cluster. It is not being used. Hidden from customers.
  version: Version specifies the expected ArgoCD version to manage. It is
    only for Ranthos to use/change. Hidden from customers.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	9ConfigDeliveryArgoCDMembershipSpec.ChannelValueValuesEnumi  a  Channel specifies a channel that can be used to resolve a specific
addon. Margo will use the same release channel as the current cluster. It
is not being used. Hidden from customers.

Values:
  CHANNEL_UNSPECIFIED: CHANNEL_UNSPECIFIED is the default unspecified
    channel field.
  REGULAR: REGULAR refers to access the ConfigDeliveryArgoCD feature
    reasonably soon after they debut, but on a version that has been
    qualified over a longer period of time.
  RAPID: RAPID refers to get the latest ConfigDeliveryArgoCD release as
    early as possible, and be able to use new features the moment they go
    GA.
  STABLE: STABLE refers to prioritize stability over new functionality.
r   r   r(   r0   r   N)
r   r   r   r   r   CHANNEL_UNSPECIFIEDREGULARRAPIDSTABLEr   r   r   r   ChannelValueValuesEnumrw    s     GEFr   r|  r   r(   r   N)r   r   r   r   r   r   r6   r|  r:   channelr    r   r   r   r   r   ru  ru    s<    y~~ *  8!<'!!!$'r   ru  c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)#ConfigDeliveryArgoCDMembershipStatei  aC  MembershipState defines the state of the Margo reconciliation objects.

Fields:
  cluster: The user-defined name for the cluster used by ClusterSelectors to
    group clusters together. This should match Membership's membership_name,
  margoState: This state describes the state of all the deployable ArgoCD
    manifests.
r   rr  r(   r   N)r   r   r   r   r   r   r    clusterr   
margoStater   r   r   r   r  r    s,     !!!$'%%&LaP*r   r  c                   <    \ rS rSrSr\R                  " S5      rSrg)ConfigManagementBinauthzConfigi  z\Configuration for Binauthz

Fields:
  enabled: Whether binauthz is enabled in this cluster.
r   r   N)	r   r   r   r   r   r   r8   enabledr   r   r   r   r  r    s     ""1%'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Srg	)
ConfigManagementBinauthzStatei  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	)
4ConfigManagementBinauthzState.WebhookValueValuesEnumi  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(   r0   r?   r   Nr   r   r   r   r   DEPLOYMENT_STATE_UNSPECIFIEDNOT_INSTALLED	INSTALLEDERRORr   r   r   r   r   WebhookValueValuesEnumr    #     $% MIEGr   r  ConfigManagementBinauthzVersionr   r(   r   N)r   r   r   r   r   r   r6   r  r   r   r:   webhookr   r   r   r   r  r    s?    y~~   ""#DaH' 8!<'r   r  c                   <    \ rS rSrSr\R                  " S5      rSrg)r  i  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   r  r    s     ((+.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)ConfigManagementConfigSynci  a  Configuration for Config Sync

Fields:
  deploymentOverrides: Optional. Configuration for deployment overrides.
  enabled: Optional. 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: Optional. Git repo configuration for the cluster.
  metricsGcpServiceAccountEmail: Optional. 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: Optional. OCI repo configuration for the cluster
  preventDrift: Optional. Set to true to enable the Config Sync admission
    webhook to prevent drifts. If set to `false`, disables the Config Sync
    admission webhook and does not prevent drifts.
  sourceFormat: Optional. Specifies whether the Config Sync Repo is in
    "hierarchical" or "unstructured" mode.
  stopSyncing: Optional. Set to true to stop syncing configs for a single
    cluster. Default to false.
"ConfigManagementDeploymentOverrider   Tr&   r(   ConfigManagementGitConfigr0   r?   ConfigManagementOciConfigr@   rA   r   r  r   N)r   r   r   r   r   r   r   deploymentOverridesr8   r  gitr    metricsGcpServiceAccountEmailocipreventDriftsourceFormatstopSyncingr   r   r   r   r  r    s    > "../SUVaef""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) )ConfigManagementConfigSyncDeploymentStatei,  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	)
IConfigManagementConfigSyncDeploymentState.AdmissionWebhookValueValuesEnumiI  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(   r0   r?   r   Nr  r   r   r   AdmissionWebhookValueValuesEnumr  I  r  r   r  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
@ConfigManagementConfigSyncDeploymentState.GitSyncValueValuesEnumiY  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(   r0   r?   r   Nr  r   r   r   GitSyncValueValuesEnumr  Y  r  r   r  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
AConfigManagementConfigSyncDeploymentState.ImporterValueValuesEnumii  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(   r0   r?   r   Nr  r   r   r   ImporterValueValuesEnumr  i  r  r   r  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
@ConfigManagementConfigSyncDeploymentState.MonitorValueValuesEnumiy  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(   r0   r?   r   Nr  r   r   r   MonitorValueValuesEnumr  y  r  r   r  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
FConfigManagementConfigSyncDeploymentState.OtelCollectorValueValuesEnumi  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(   r0   r?   r   Nr  r   r   r   OtelCollectorValueValuesEnumr    r  r   r  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
JConfigManagementConfigSyncDeploymentState.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(   r0   r?   r   Nr  r   r   r    ReconcilerManagerValueValuesEnumr    r  r   r  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
WConfigManagementConfigSyncDeploymentState.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(   r0   r?   r   Nr  r   r   r   -ResourceGroupControllerManagerValueValuesEnumr    r  r   r  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
GConfigManagementConfigSyncDeploymentState.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(   r0   r?   r   Nr  r   r   r   RootReconcilerValueValuesEnumr    r  r   r  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
?ConfigManagementConfigSyncDeploymentState.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(   r0   r?   r   Nr  r   r   r   SyncerValueValuesEnumr    r  r   r  r   r(   r0   r?   r@   rA   r   r  r
  r   N)r   r   r   r   r   r   r6   r  r  r  r  r  r  r  r  r  r:   admissionWebhookgitSyncimportermonitorotelCollectorreconcilerManagerresourceGroupControllerManagerrootReconcilersyncerr   r   r   r   r  r  ,  sH   8	  y~~  	  y~~  Y^^    inn  inn  inn   (()JAN 8!<'  !:A>( 8!<'%%&DaH-))*LaP#,#6#67fhi#j &&'FJ.6:&r   r  c                   <    \ rS rSrSr\R                  " S5      rSrg)ConfigManagementConfigSyncErrori  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   r  r         &&q),r   r  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)ConfigManagementConfigSyncStatei  a  State information for ConfigSync

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

Fields:
  clusterLevelStopSyncingState: Output only. 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: Output only. Information about the deployment of
    ConfigSync, including the version of the various Pods deployed
  errors: Output only. Errors pertaining to the installation of Config Sync.
  reposyncCrd: Output only. The state of the Reposync CRD
  rootsyncCrd: Output only. The state of the RootSync CRD
  state: Output only. The state of CS This field summarizes the other fields
    in this message.
  syncState: Output only. The state of ConfigSync's process to sync configs
    to a cluster
  version: Output only. The version of ConfigSync deployed
c                   (    \ rS rSrSrSrSrSrSrSr	g)	KConfigManagementConfigSyncState.ClusterLevelStopSyncingStateValueValuesEnumi
  a  Output only. 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(   r0   r   N)
r   r   r   r   r   STOP_SYNCING_STATE_UNSPECIFIEDNOT_STOPPEDr   STOPPEDr   r   r   r   +ClusterLevelStopSyncingStateValueValuesEnumr  
  s     &'"KGGr   r  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
:ConfigManagementConfigSyncState.ReposyncCrdValueValuesEnumi  a'  Output only. 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(   r0   r?   r   Nr   r   r   r   r   CRD_STATE_UNSPECIFIEDr  r  TERMINATING
INSTALLINGr   r   r   r   ReposyncCrdValueValuesEnumr    #    	 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	)
:ConfigManagementConfigSyncState.RootsyncCrdValueValuesEnumi-  a'  Output only. 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(   r0   r?   r   Nr  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	)
4ConfigManagementConfigSyncState.StateValueValuesEnumi>  ay  Output only. 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(   r0   r?   r   N)r   r   r   r   r   r   CONFIG_SYNC_NOT_INSTALLEDCONFIG_SYNC_INSTALLEDCONFIG_SYNC_ERRORCONFIG_SYNC_PENDINGr   r   r   r   r   r  >  s'    
  !r   r   r   r(   r   r  r0   r  r?   Tr&   r@   rA   r   ConfigManagementSyncStater  !ConfigManagementConfigSyncVersionr
  r   N)r   r   r   r   r   r   r6   r  r  r  r   r:   clusterLevelStopSyncingStater   r   r   crCountr   deploymentStateerrorsreposyncCrdrootsyncCrdr   	syncStater   r   r   r   r   r  r    s   6INN $9>> "9>> "Y^^ $ "+!4!45bde!f""1i.?.?.E.EF'**+VXYZ/!!"CQQUV&##$@!D+##$@!D+


4a
8%$$%@!D)""#FJ'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  i[  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(   r0   r?   r@   rA   r   r  r
  r   N)r   r   r   r   r   r   r    r  r  r  r  r  r  r  r  r  r   r   r   r   r  r  [  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	)
!ConfigManagementContainerOverrideiw  aS  Configuration for a container override.

Fields:
  containerName: Required. The name of the container.
  cpuLimit: Optional. The cpu limit of the container.
  cpuRequest: Optional. The cpu request of the container.
  memoryLimit: Optional. The memory limit of the container.
  memoryRequest: Optional. The memory request of the container.
r   r(   r0   r?   r@   r   N)r   r   r   r   r   r   r    containerNamecpuLimit
cpuRequestmemoryLimitmemoryRequestr   r   r   r   r  r  w  sY     ''*-""1%($$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(   r0   r   N)r   r   r   r   r   r   r   
containersr    deploymentNamedeploymentNamespacer   r   r   r   r  r    s@    	 %%&I1W[\*((+.!--a0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	)
ConfigManagementErrorResourcei  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
 ConfigManagementGroupVersionKindr   r(   r0   r?   r   N)r   r   r   r   r   r   r   resourceGvkr    resourceNameresourceNamespace
sourcePathr   r   r   r   r  r    sM     &&'I1M+&&q),++A.$$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	\R                  " SS	5      r\R                  " SS
5      r\R                  " SS5      rSrg))ConfigManagementGatekeeperDeploymentStatei  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	)
HConfigManagementGatekeeperDeploymentState.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(   r0   r?   r   Nr  r   r   r   GatekeeperAuditValueValuesEnumr    r  r   r  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
YConfigManagementGatekeeperDeploymentState.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(   r0   r?   r   Nr  r   r   r   /GatekeeperControllerManagerStateValueValuesEnumr    r  r   r  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
KConfigManagementGatekeeperDeploymentState.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(   r0   r?   r   Nr  r   r   r   !GatekeeperMutationValueValuesEnumr	    r  r   r
  r   r(   r0   r   N)r   r   r   r   r   r   r6   r  r  r
  r:   gatekeeperAudit gatekeeperControllerManagerStategatekeeperMutationr   r   r   r   r  r    sv     y~~  	  )..   ''(H!L/%.%8%89jlm%n" **+NPQR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: Optional. The Google Cloud Service Account Email
    used for auth when secret_type is gcpServiceAccount.
  httpsProxy: Optional. URL for the HTTPS proxy to be used when
    communicating with the Git repo.
  policyDir: Optional. 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. Must be one of ssh, cookiefile, gcenode, token, gcpserviceaccount,
    githubapp or none. The validation of this is case-sensitive.
  syncBranch: Optional. The branch of the repository to sync from. Default:
    master.
  syncRepo: Required. The URL of the Git repository to use as the source of
    truth.
  syncRev: Optional. Git revision (tag or hash) to check out. Default HEAD.
  syncWaitSecs: Optional. Period in seconds between consecutive syncs.
    Default: 15.
r   r(   r0   r?   r@   rA   r   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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(   r0   r   N)r   r   r   r   r   r   r    groupkindr   r   r   r   r   r  r    s9     


"%			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))ConfigManagementHierarchyControllerConfigi  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(   r0   r   N)r   r   r   r   r   r   r8   enableHierarchicalResourceQuotaenablePodTreeLabelsr  r   r   r   r   r  r    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
)2ConfigManagementHierarchyControllerDeploymentStatei.  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	)
KConfigManagementHierarchyControllerDeploymentState.ExtensionValueValuesEnumi=  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(   r0   r?   r   Nr  r   r   r   ExtensionValueValuesEnumr!  =  s#    	 $% MIEGr   r"  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
EConfigManagementHierarchyControllerDeploymentState.HncValueValuesEnumiN  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(   r0   r?   r   Nr  r   r   r   HncValueValuesEnumr$  N  r  r   r%  r   r(   r   N)r   r   r   r   r   r   r6   r"  r%  r:   	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)	(ConfigManagementHierarchyControllerStateib  zState for Hierarchy Controller

Fields:
  state: The deployment state for Hierarchy Controller
  version: The version for Hierarchy Controller
r  r   *ConfigManagementHierarchyControllerVersionr(   r   N)
r   r   r   r   r   r   r   r   r   r   r   r   r   r)  r)  b  s1     
 
 !UWX
Y%""#OQRS'r   r)  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)r*  in  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    r&  r'  r   r   r   r   r*  r*  n  s)     ##A&)a #r   r*  c                   <    \ rS rSrSr\R                  " S5      rSrg)ConfigManagementInstallErroriz  zzErrors pertaining to the installation of ACM

Fields:
  errorMessage: A string representing the user facing error message
r   r   Nr  r   r   r   r-  r-  z  r  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  a  **Anthos Config Management**: Configuration for a single cluster.
Intended to parallel the ConfigManagement CR.

Enums:
  ManagementValueValuesEnum: Optional. Enables automatic Feature management.

Fields:
  binauthz: Optional. Binauthz conifguration for the cluster. Deprecated:
    This field will be ignored and should not be set.
  cluster: Optional. 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: Optional. Config Sync configuration for the cluster.
  hierarchyController: Optional. 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: Optional. Enables automatic Feature management.
  policyController: Optional. Policy Controller configuration for the
    cluster. Deprecated: Configuring Policy Controller through the
    configmanagement feature is no longer recommended. Use the
    policycontroller feature instead.
  version: Optional. Version of ACM installed.
c                   $    \ rS rSrSrSrSrSrSrg)8ConfigManagementMembershipSpec.ManagementValueValuesEnumi  zOptional. Enables 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   ManagementValueValuesEnumr0    s     r   r4  r  r   r(   r  r0   r  r?   r@    ConfigManagementPolicyControllerrA   r   r   N)r   r   r   r   r   r   r6   r4  r   binauthzr    r  
configSynchierarchyControllerr:   
managementpolicyControllerr   r   r   r   r   r,  r,    s    :)..  ##$DaH(!!!$'%%&BAF*!../Z\]^""#>B*++,NPQR!!!$'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)ConfigManagementMembershipStatei  aU  **Anthos Config Management**: State for a single cluster.

Fields:
  binauthzState: Output only. Binauthz status
  clusterName: Output only. 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: Output only. Current sync status
  hierarchyControllerState: Output only. Hierarchy Controller status
  kubernetesApiServerVersion: Output only. The Kubernetes API server version
    of the cluster.
  membershipSpec: Output only. Membership configuration in the cluster. This
    represents the actual state in the cluster, while the MembershipSpec in
    the FeatureSpec represents the intended state
  operatorState: Output only. Current install status of ACM's Operator
  policyControllerState: Output only. PolicyController status
r  r   r(   r  r0   r)  r?   r@   r,  rA   ConfigManagementOperatorStater   %ConfigManagementPolicyControllerStater  r   N)r   r   r   r   r   r   r   binauthzStater    clusterNameconfigSyncStatehierarchyControllerStatekubernetesApiServerVersionmembershipSpecoperatorStatepolicyControllerStater   r   r   r   r<  r<    s    $ (()H!L-%%a(+**+LaP/&334^`ab(44Q7))*JAN.(()H!L-#001XZ[\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	)
r  i  a  OCI repo configuration for a single cluster

Fields:
  gcpServiceAccountEmail: Optional. The Google Cloud Service Account Email
    used for auth when secret_type is gcpServiceAccount.
  policyDir: Optional. The absolute path of the directory that contains the
    local resources. Default: the root directory of the image.
  secretType: Required. Type of secret configured for access to the OCI
    repo. Must be one of gcenode, gcpserviceaccount, k8sserviceaccount or
    none. The validation of this is case-sensitive.
  syncRepo: Required. The OCI image repository URL for the package to sync
    from. e.g. `LOCATION-
    docker.pkg.dev/PROJECT_ID/REPOSITORY_NAME/PACKAGE_NAME`.
  syncWaitSecs: Optional. Period in seconds between consecutive syncs.
    Default: 15.
r   r(   r0   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 " S S\R                  5      r\R                  " SS5      r	\R                  " SSSS	9r\R                  " S
5      rSrg)r=  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	)
<ConfigManagementOperatorState.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(   r0   r?   r   Nr  r   r   r   DeploymentStateValueValuesEnumrJ    r  r   rK  r   r-  r(   Tr&   r0   r   N)r   r   r   r   r   r   r6   rK  r:   r  r   r  r    r   r   r   r   r   r=  r=    sQ    	y~~   ''(H!L/!!"@!dS&!!!$'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)r5  i  aW  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 or disable mutation in policy controller. If true,
    mutation CRDs, webhook and controller deployment will be deployed to the
    cluster.
  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(   r0   Tr&   r?   *ConfigManagementPolicyControllerMonitoringr@   rA   r   r  r
  r   N)r   r   r   r   r   r   r   auditIntervalSecondsr8   r  r    exemptableNamespaceslogDeniesEnabledr   
monitoringmutationEnabledreferentialRulesEnabledtemplateLibraryInstalledr   r   r   r   r   r5  r5    s    0 #//2""1%'"..q4@++A.%%&RTUV***1-/%2215&33A6$$Q'*r   r5  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)	)ConfigManagementPolicyControllerMigrationi3  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)>ConfigManagementPolicyControllerMigration.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   StageValueValuesEnumrX  >  s     KLr   r\  r   r(   r   N)r   r   r   r   r   r   r6   r\  r    copyTimer:   stager   r   r   r   rV  rV  3  s<    Y^^  ""1%(


4a
8%r   rV  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
rM  iP  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)KConfigManagementPolicyControllerMonitoring.BackendsValueListEntryValuesEnumi^  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    BackendsValueListEntryValuesEnumra  ^       &'"Jr   rg  r   Tr&   r   Nr   r   r   r   r   r   r6   rg  r:   backendsr   r   r   r   rM  rM  P  /    
 
   !CQQUV(r   rM  c                       \ rS rSrSr\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r	S	r
g
)r>  im  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   rV  r(   'ConfigManagementPolicyControllerVersionr0   r   N)r   r   r   r   r   r   r   r  	migrationr   r   r   r   r   r>  r>  m  sD     **+VXYZ/$$%PRST)""#LaP'r   r>  c                   <    \ rS rSrSr\R                  " S5      rSrg)rm  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    r   r   r   r   r   rm  rm  {  s     !!!$'r   rm  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
)ConfigManagementSyncErrori  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  r0   Tr&   r   N)r   r   r   r   r   r   r    r   r  r   errorResourcesr   r   r   r   rq  rq    s?     
		q	!$&&q),))*I1W[\.r   rq  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: Deprecated: use last_sync_time instead. Timestamp of when ACM
    last successfully synced the repo The time format is specified in
    https://golang.org/pkg/time/#Time.String
  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)-ConfigManagementSyncState.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(   r0   r?   r@   rA   r   r   N)r   r   r   r   r   SYNC_CODE_UNSPECIFIEDSYNCEDr   r  NOT_CONFIGUREDr  UNAUTHORIZEDUNREACHABLEr   r   r   r   r   ru    s2     FGENMLKr   r   r   rq  r(   Tr&   r0   r?   r@   rA   r   r   N)r   r   r   r   r   r   r6   r   r:   r   r   r  r    importTokenlastSynclastSyncTimesourceToken	syncTokenr   r   r   r   r  r    s    &INN . 
		2A	6$!!"=q4P&%%a(+""1%(&&q),%%a(+##A&)r   r  c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)ConnectAgentResourcei  zConnectAgentResource represents a Kubernetes resource manifest for
Connect Agent deployment.

Fields:
  manifest: YAML manifest of the resource.
  type: Kubernetes type of the resource.
r   TypeMetar(   r   N)r   r   r   r   r   r   r    manifestr   r   r   r   r   r   r  r    s+     ""1%(			
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
)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(   r0   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(   r0   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  i	  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    r   r   r   r   r   r   r  r  	  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)	DataAccessOptionsi	  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.LogModeValueValuesEnumi%	  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  %	  s    " Or   r  r   r(   r   N)r   r   r   r   r   r   r6   r  r8   isDirectAuthr:   logModer   r   r   r   r  r  	  s<    y~~ * ''*, 8!<'r   r  c                   <    \ rS rSrSr\R                  " S5      rSrg)r  i>	  zt**Dataplane V2**: Spec

Fields:
  enableEncryption: Enable dataplane-v2 based encryption for multiple
    clusters.
r   r   N)	r   r   r   r   r   r   r8   enableEncryptionr   r   r   r   r  r  >	  s     ++A.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	S	r
g
)DefaultClusterConfigiI	  a-  DefaultClusterConfig describes the default cluster configurations to be
applied to all clusters born-in-fleet.

Fields:
  binaryAuthorizationConfig: Optional. Enable/Disable binary authorization
    features for the cluster.
  compliancePostureConfig: Optional. Enable/Disable Compliance Posture
    features for the cluster. Note that on UpdateFleet, only full
    replacement of this field is allowed. Users are not allowed for partial
    updates through field mask.
  securityPostureConfig: Enable/Disable Security Posture features for the
    cluster.
rU   r   r5  r(   SecurityPostureConfigr0   r   N)r   r   r   r   r   r   r   binaryAuthorizationConfigcompliancePostureConfigsecurityPostureConfigr   r   r   r   r  r  I	  sF     (445PRST%223LaP#001H!L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    r   r  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Sr	g)EdgeClusterio	  ap  EdgeCluster contains information specific to Google Edge Clusters.

Fields:
  clusterVersion: Output only. The product version of the Edge Cluster, e.g.
    "1.8.0".
  resourceLink: Immutable. Self-link of the Google Cloud resource for the
    Edge Cluster. For example: //edgecontainer.googleapis.com/projects/my-
    project/locations/us-west1-a/clusters/my-cluster
r   r(   r   N)
r   r   r   r   r   r   r    clusterVersionr!   r   r   r   r   r  r  o	  s)     ((+.&&q),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  ~	  s    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)	ExcludedClusteri	  aW  An excluded cluster from the rollout.

Enums:
  ReasonValueValuesEnum: Output only. The reason for excluding the cluster
    from the rollout.

Fields:
  membership: Output only. The name of the fleet Membership resource
    associated to the excluded cluster.
  reason: Output only. The reason for excluding the cluster from the
    rollout.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	%ExcludedCluster.ReasonValueValuesEnumi	  a!  Output only. The reason for excluding the cluster from the rollout.

Values:
  REASON_UNSPECIFIED: Default value.
  EXCLUDED_BY_FILTER: The cluster was excluded by the rollout filter.
  ALREADY_UPGRADED: The cluster was already upgraded.
  VERSION_TOO_OLD: The cluster version is too old.
r   r   r(   r0   r   N)
r   r   r   r   r   REASON_UNSPECIFIEDEXCLUDED_BY_FILTERALREADY_UPGRADEDVERSION_TOO_OLDr   r   r   r   ReasonValueValuesEnumr  	  s      Or   r  r   r(   r   N)r   r   r   r   r   r   r6   r  r    r   r:   r   r   r   r   r   r  r  	  s<    inn  $$Q'*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
Srg)	rd   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(   r0   r?   r   N)r   r   r   r   r   r   r    description
expressionlocationtitler   r   r   r   rd   rd   	  sI    : %%a(+$$Q'*""1%(



"%r   rd   c                      \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " S5       " S S\R                  5      5       r
\R                  " S5       " S S	\R                  5      5       r\R                  " S5       " S
 S\R                  5      5       r\R                  " S5       " S S\R                  5      5       r\R                  " S5      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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 S!9r\R                  " S"5      rS#rg$)%Featurei	  a
  Feature represents the settings and status of any Fleet Feature.

Messages:
  LabelsValue: Labels for this Feature.
  MembershipSpecsValue: Optional. Membership-specific configuration for this
    Feature. If this Feature does not support any per-Membership
    configuration, this field may be unused. The keys indicate which
    Membership the configuration is for, in the form:
    `projects/{p}/locations/{l}/memberships/{m}` Where {p} is the project,
    {l} is a valid location and {m} is a valid Membership in this project at
    that location. {p} WILL match the Feature's project. {p} will always be
    returned as the project number, but the project ID is also accepted
    during input. If the same Membership is specified in the map twice
    (using the project ID form, and the project number form), exactly ONE of
    the entries will be saved, with no guarantees as to which. For this
    reason, it is recommended the same format be used for all entries when
    mutating a Feature.
  MembershipStatesValue: Output only. Membership-specific Feature status. If
    this Feature does report any per-Membership status, this field may be
    unused. The keys indicate which Membership the state is for, in the
    form: `projects/{p}/locations/{l}/memberships/{m}` Where {p} is the
    project number, {l} is a valid location and {m} is a valid Membership in
    this project at that location. {p} MUST match the Feature's project
    number.
  ScopeSpecsValue: Optional. Scope-specific configuration for this Feature.
    If this Feature does not support any per-Scope configuration, this field
    may be unused. The keys indicate which Scope the configuration is for,
    in the form: `projects/{p}/locations/global/scopes/{s}` Where {p} is the
    project, {s} is a valid Scope in this project. {p} WILL match the
    Feature's project. {p} will always be returned as the project number,
    but the project ID is also accepted during input. If the same Scope is
    specified in the map twice (using the project ID form, and the project
    number form), exactly ONE of the entries will be saved, with no
    guarantees as to which. For this reason, it is recommended the same
    format be used for all entries when mutating a Feature.
  ScopeStatesValue: Output only. Scope-specific Feature status. If this
    Feature does report any per-Scope status, this field may be unused. The
    keys indicate which Scope the state is for, in the form:
    `projects/{p}/locations/global/scopes/{s}` Where {p} is the project, {s}
    is a valid Scope in this project. {p} WILL match the Feature's project.

Fields:
  createTime: Output only. When the Feature resource was created.
  deleteTime: Output only. When the Feature resource was deleted.
  etag: Optional. This checksum is computed by the server based on the value
    of other fields, and may be sent on update and delete requests to ensure
    the client has an up-to-date value before proceeding.
  fleetDefaultMemberConfig: Optional. Feature configuration applicable to
    all memberships of the fleet.
  labels: Labels for this Feature.
  membershipSpecs: Optional. Membership-specific configuration for this
    Feature. If this Feature does not support any per-Membership
    configuration, this field may be unused. The keys indicate which
    Membership the configuration is for, in the form:
    `projects/{p}/locations/{l}/memberships/{m}` Where {p} is the project,
    {l} is a valid location and {m} is a valid Membership in this project at
    that location. {p} WILL match the Feature's project. {p} will always be
    returned as the project number, but the project ID is also accepted
    during input. If the same Membership is specified in the map twice
    (using the project ID form, and the project number form), exactly ONE of
    the entries will be saved, with no guarantees as to which. For this
    reason, it is recommended the same format be used for all entries when
    mutating a Feature.
  membershipStates: Output only. Membership-specific Feature status. If this
    Feature does report any per-Membership status, this field may be unused.
    The keys indicate which Membership the state is for, in the form:
    `projects/{p}/locations/{l}/memberships/{m}` Where {p} is the project
    number, {l} is a valid location and {m} is a valid Membership in this
    project at that location. {p} MUST match the Feature's project number.
  name: Output only. The full, unique name of this Feature resource in the
    format `projects/*/locations/*/features/*`.
  resourceState: Output only. State of the Feature resource itself.
  scopeSpecs: Optional. Scope-specific configuration for this Feature. If
    this Feature does not support any per-Scope configuration, this field
    may be unused. The keys indicate which Scope the configuration is for,
    in the form: `projects/{p}/locations/global/scopes/{s}` Where {p} is the
    project, {s} is a valid Scope in this project. {p} WILL match the
    Feature's project. {p} will always be returned as the project number,
    but the project ID is also accepted during input. If the same Scope is
    specified in the map twice (using the project ID form, and the project
    number form), exactly ONE of the entries will be saved, with no
    guarantees as to which. For this reason, it is recommended the same
    format be used for all entries when mutating a Feature.
  scopeStates: Output only. Scope-specific Feature status. If this Feature
    does report any per-Scope status, this field may be unused. The keys
    indicate which Scope the state is for, in the form:
    `projects/{p}/locations/global/scopes/{s}` Where {p} is the project, {s}
    is a valid Scope in this project. {p} WILL match the Feature's project.
  spec: Optional. Fleet-wide Feature configuration. If this Feature does not
    support any Fleet-wide configuration, this field may be unused.
  state: Output only. The Fleet-wide Feature state.
  unreachable: Output only. List of locations that could not be reached
    while fetching this feature.
  updateTime: Output only. When the Feature resource was last updated.
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.LabelsValuei,
  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.AdditionalPropertyi7
  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  7
  )    
 !!!$c##A&er   r   r   Tr&   r   Nr   r   r   r   LabelsValuer  ,
  2    	'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	)
Feature.MembershipSpecsValueiD
  a  Optional. Membership-specific configuration for this Feature. If this
Feature does not support any per-Membership configuration, this field may
be unused. The keys indicate which Membership the configuration is for, in
the form: `projects/{p}/locations/{l}/memberships/{m}` Where {p} is the
project, {l} is a valid location and {m} is a valid Membership in this
project at that location. {p} WILL match the Feature's project. {p} will
always be returned as the project number, but the project ID is also
accepted during input. If the same Membership is specified in the map
twice (using the project ID form, and the project number form), exactly
ONE of the entries will be saved, with no guarantees as to which. For this
reason, it is recommended the same format be used for all entries when
mutating a Feature.

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)/Feature.MembershipSpecsValue.AdditionalPropertyi[
  zAn additional property for a MembershipSpecsValue object.

Fields:
  key: Name of the additional property.
  value: A MembershipFeatureSpec attribute.
r   MembershipFeatureSpecr(   r   Nr   r   r   r   r   r  [
  ,    
 !!!$c$$%<a@er   r   r   Tr&   r   Nr   r   r   r   MembershipSpecsValuer  D
  s4    *	AY.. 	A %112FTXYr   r  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
Feature.MembershipStatesValueih
  aP  Output only. Membership-specific Feature status. If this Feature does
report any per-Membership status, this field may be unused. The keys
indicate which Membership the state is for, in the form:
`projects/{p}/locations/{l}/memberships/{m}` Where {p} is the project
number, {l} is a valid location and {m} is a valid Membership in this
project at that location. {p} MUST match the Feature's project number.

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

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

Fields:
  key: Name of the additional property.
  value: A MembershipFeatureState attribute.
r   MembershipFeatureStater(   r   Nr   r   r   r   r   r  z
  ,    
 !!!$c$$%=qAer   r   r   Tr&   r   Nr   r   r   r   MembershipStatesValuer  h
  s4     	BY.. 	B %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	)
Feature.ScopeSpecsValuei
  a  Optional. Scope-specific configuration for this Feature. If this
Feature does not support any per-Scope configuration, this field may be
unused. The keys indicate which Scope the configuration is for, in the
form: `projects/{p}/locations/global/scopes/{s}` Where {p} is the project,
{s} is a valid Scope in this project. {p} WILL match the Feature's
project. {p} will always be returned as the project number, but the
project ID is also accepted during input. If the same Scope is specified
in the map twice (using the project ID form, and the project number form),
exactly ONE of the entries will be saved, with no guarantees as to which.
For this reason, it is recommended the same format be used for all entries
when mutating a Feature.

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

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

Fields:
  key: Name of the additional property.
  value: A ScopeFeatureSpec attribute.
r   ScopeFeatureSpecr(   r   Nr   r   r   r   r   r  
  ,    
 !!!$c$$%7;er   r   r   Tr&   r   Nr   r   r   r   ScopeSpecsValuer  
  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	)
Feature.ScopeStatesValuei
  a  Output only. Scope-specific Feature status. If this Feature does
report any per-Scope status, this field may be unused. The keys indicate
which Scope the state is for, in the form:
`projects/{p}/locations/global/scopes/{s}` Where {p} is the project, {s}
is a valid Scope in this project. {p} WILL match the Feature's project.

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

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

Fields:
  key: Name of the additional property.
  value: A ScopeFeatureState attribute.
r   ScopeFeatureStater(   r   Nr   r   r   r   r   r  
  s,    
 !!!$c$$%8!<er   r   r   Tr&   r   Nr   r   r   r   ScopeStatesValuer  
  s2    	=Y.. 	= %112FTXYr   r  r   r(   r0   r+  r?   r@   rA   r   r  FeatureResourceStater
  r  r  r  r  r!  r     Tr&      r   N) r   r   r   r   r   r   r   r   r   r  r  r  r  r  r    
createTime
deleteTimeetagr   fleetDefaultMemberConfiglabelsmembershipSpecsmembershipStatesr   resourceState
scopeSpecsscopeStatesspecr   unreachabler   r   r   r   r   r  r  	  s   ^@ !!"89ZI%% Z :Z. !!"89!ZY.. !Z :!ZF !!"89Zi// Z :Z< !!"89Z	)) Z :ZB !!"89Z** Z :Z8 $$Q'*$$Q'*			q	!$&334XZ[\!!-3&**+A1E/++,CQG			q	!$(()?C-%%&7<*&&'92>+			 3R	8$

 
 !5r
:%%%b48+$$R(*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]  FeatureResourceState describes the state of a Feature *resource* in the
GkeHub API. See `FeatureState` for the "running state" of the Feature in the
Fleet and across Memberships.

Enums:
  StateValueValuesEnum: The current state of the Feature resource in the Hub
    API.

Fields:
  state: The current state of the Feature resource in the Hub API.
c                   0    \ rS rSrSrSrSrSrSrSr	Sr
S	rg
))FeatureResourceState.StateValueValuesEnumi
  ai  The current state of the Feature resource in the Hub API.

Values:
  STATE_UNSPECIFIED: State is unknown or not set.
  ENABLING: The Feature is being enabled, and the Feature resource is
    being created. Once complete, the corresponding Feature will be
    enabled in this Fleet.
  ACTIVE: The Feature is enabled in this Fleet, and the Feature resource
    is fully available.
  DISABLING: The Feature is being disabled in this Fleet, and the Feature
    resource is being deleted.
  UPDATING: The Feature resource is being updated.
  SERVICE_UPDATING: The Feature resource is being updated by the Hub
    Service.
r   r   r(   r0   r?   r@   r   N)r   r   r   r   r   r   ENABLINGACTIVE	DISABLINGUPDATINGSERVICE_UPDATINGr   r   r   r   r   r  
  s)     HFIHr   r   r   r   N)r   r   r   r   r   r   r6   r   r:   r   r   r   r   r   r  r  
  s,    
Y^^ . 

4a
8%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Srg	)
r  i
  ah  **Workload Certificate**: The Hub-wide input for the WorkloadCertificate
feature.

Enums:
  ProvisionGoogleCaValueValuesEnum: Immutable. Specifies CA configuration.

Fields:
  defaultConfig: Specifies default membership spec. Users can override the
    default in the member_configs for each member.
  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	)
,FeatureSpec.ProvisionGoogleCaValueValuesEnumi  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(   r0   r?   r   N)r   r   r   r   r   "GOOGLE_CA_PROVISIONING_UNSPECIFIEDr[   r9  ENABLED_WITH_MANAGED_CAENABLED_WITH_DEFAULT_CAr   r   r   r    ProvisionGoogleCaValueValuesEnumr    s%     *+&HGr   r  MembershipSpecr   r(   r   N)r   r   r   r   r   r   r6   r  r   defaultConfigr:   provisionGoogleCar   r   r   r   r  r  
  s@    
   ( (()91=-))*LaPr   r  c                       \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	\R                  " S5      r\R                  " S5      rSrg	)
r'  i#  a  FeatureState describes the high-level state of a Feature. It may be used
to describe a Feature's state at the environ-level, or per-membershop,
depending on the context.

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

Fields:
  code: The high-level, machine-readable status of this Feature.
  description: A human-readable description of the current status.
  updateTime: The time this status and any related Feature-specific details
    were updated.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	 FeatureState.CodeValueValuesEnumi3  az  The high-level, machine-readable status of this Feature.

Values:
  CODE_UNSPECIFIED: Unknown or not set.
  OK: The Feature is operating normally.
  WARNING: The Feature has encountered an issue, and is operating in a
    degraded state. The Feature may need intervention to return to normal
    operation. See the description and any associated Feature-specific
    details for more information.
  ERROR: The Feature is not operating or is in a severely degraded state.
    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(   r0   r   N)
r   r   r   r   r   r   OKWARNINGr  r   r   r   r   r   r  3  s     	
BGEr   r   r   r(   r0   r   N)r   r   r   r   r   r   r6   r   r:   r   r    r  r   r   r   r   r   r'  r'  #  sL    INN ( 
		2A	6$%%a(+$$Q'*r   r'  c                   d    \ rS rSrSr\R                  " SS5      r\R                  " SS5      rSr	g)	FeatureUpdateiL  zFeature config to use for Rollout.

Fields:
  binaryAuthorizationConfig: Optional. Configuration for Binary
    Authorization.
  securityPostureConfig: Optional. Configuration for Security Posture.
rU   r   r  r(   r   N)
r   r   r   r   r   r   r   r  r  r   r   r   r   r  r  L  s2     (445PRST#001H!Lr   r  c                      \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " S5      r\R                  " SS5      r\R                  " S	5      r\R                  " S
5      r\R                  " SS5      r\R                  " S5      r\R                  " SS5      r\R                  " S5      r\R                  " S5      rSrg)FleetiY  a  Fleet contains the Fleet-wide metadata and configuration.

Messages:
  LabelsValue: Optional. Labels for this Fleet.

Fields:
  createTime: Output only. When the Fleet was created.
  defaultClusterConfig: Optional. The default cluster configurations to
    apply across the fleet.
  deleteTime: Output only. When the Fleet was deleted.
  displayName: Optional. A user-assigned display name of the Fleet. When
    present, it must be between 4 to 30 characters. Allowed characters are:
    lowercase and uppercase letters, numbers, hyphen, single-quote, double-
    quote, space, and exclamation point. Example: `Production Fleet`
  labels: Optional. Labels for this Fleet.
  name: Output only. The full, unique resource name of this fleet in the
    format of `projects/{project}/locations/{location}/fleets/{fleet}`. Each
    Google Cloud project can have at most one fleet resource, named
    "default".
  state: Output only. State of the namespace resource.
  uid: Output only. Google-generated UUID for this resource. This is unique
    across all Fleet resources. If a Fleet resource is deleted and another
    resource with the same name is created, it gets a different uid.
  updateTime: Output only. When the Fleet was last updated.
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	)
Fleet.LabelsValueit  zOptional. Labels for this Fleet.

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)$Fleet.LabelsValue.AdditionalPropertyi  r  r   r(   r   Nr  r   r   r   r   r    r  r   r   r   Tr&   r   Nr   r   r   r   r  r
  t  r  r   r  r   r  r(   r0   r?   r@   rA   FleetLifecycleStater   r  r
  r   N)r   r   r   r   r   r   r   r   r   r  r    r  r   defaultClusterConfigr  displayNamer  r   r   uidr   r   r   r   r   r  r  Y  s    4 !!"89ZI%% Z :Z. $$Q'*"//0FJ$$Q'*%%a(+!!-3&			q	!$

 
 !6
:%a #$$Q'*r   r  c                   h    \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	Sr
g)r  i  zFleetLifecycleState describes the state of a Fleet resource.

Enums:
  CodeValueValuesEnum: Output only. The current state of the Fleet resource.

Fields:
  code: Output only. The current state of the Fleet resource.
c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
'FleetLifecycleState.CodeValueValuesEnumi  zOutput only. The current state of the Fleet resource.

Values:
  CODE_UNSPECIFIED: The code is not set.
  CREATING: The fleet is being created.
  READY: The fleet active.
  DELETING: The fleet is being deleted.
  UPDATING: The fleet is being updated.
r   r   r(   r0   r?   r   Nr   r   r   r   r   r   CREATINGrn  DELETINGr  r   r   r   r   r   r    #     HEHHr   r   r   r   Nr   r   r   r   r   r   r6   r   r:   r   r   r   r   r   r  r    ,    INN   
		2A	6$r   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)FleetObservabilityFeatureErrori  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                   >    \ rS rSrSr\R                  " SS5      rSrg)r  i  z**Fleet Observability**: The Hub-wide input for the FleetObservability
feature.

Fields:
  loggingConfig: Specified if fleet logging feature is enabled for the
    entire fleet. If UNSPECIFIED, fleet logging feature is disabled for the
    entire fleet.
FleetObservabilityLoggingConfigr   r   N)	r   r   r   r   r   r   r   loggingConfigr   r   r   r   r  r    s     (()JAN-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  z**FleetObservability**: Hub-wide Feature for FleetObservability feature.
state.

Fields:
  logging: The feature state of default logging.
  monitoring: The feature state of fleet monitoring.
0FleetObservabilityFleetObservabilityLoggingStater   3FleetObservabilityFleetObservabilityMonitoringStater(   r   N)
r   r   r   r   r   r   r   loggingrQ  r   r   r   r   r"  r"    s1     ""#UWXY'%%&[]^_*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)4FleetObservabilityFleetObservabilityBaseFeatureStatei  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)HFleetObservabilityFleetObservabilityBaseFeatureState.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   r  r  r   r   r   r   r   r&    s    	 	
BEr   r   r   r  r(   Tr&   r   N)r   r   r   r   r   r   r6   r   r:   r   r   r  r   r   r   r   r$  r$    sB    
INN  
		2A	6$!!"BAPTU&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  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     s1     %%&\^_`*##$Z\]^(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     
 
 !WYZ
[%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  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.
FleetObservabilityRoutingConfigr   r(   r   N)
r   r   r   r   r   r   r   r  fleetScopeLogsConfigr   r   r   r   r  r    s1     (()JAN-"//0QSTUr   r  c                       \ rS rSrSrSrg) FleetObservabilityMembershipSpeci  zV**FleetObservability**: The membership-specific input for
FleetObservability feature.
r   Nr   r   r   r   r/  r/        r   r/  c                       \ rS rSrSrSrg)!FleetObservabilityMembershipStatei%  zR**FleetObservability**: Membership-specific Feature state for
fleetobservability.
r   Nr   r   r   r   r2  r2  %  r0  r   r2  c                   h    \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	Sr
g)r,  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)3FleetObservabilityRoutingConfig.ModeValueValuesEnumi6  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   r8  COPYMOVEr   r   r   r   r:  r5  6  s     DDr   r:  r   r   N)r   r   r   r   r   r   r6   r:  r:   r=  r   r   r   r   r,  r,  ,  s,    
INN 
 
		2A	6$r   r,  c                   <    \ rS rSrSr\R                  " SSSS9rSrg)	GenerateConnectManifestResponseiE  zGenerateConnectManifestResponse contains manifest information for
installing/upgrading a Connect agent.

Fields:
  manifest: The ordered list of Kubernetes resources that need to be applied
    to the cluster for GKE Connect agent installation/upgrade.
r  r   Tr&   r   N)	r   r   r   r   r   r   r   r  r   r   r   r   r9  r9  E  s     ##$:AM(r   r9  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)#GenerateExclusivityManifestResponseiQ  a  The response of the exclusivity artifacts manifests for the client to
apply.

Fields:
  crManifest: The YAML manifest of the membership CR to apply if a new
    version of the CR is available. Empty if no update needs to be applied.
  crdManifest: The YAML manifest of the membership CRD to apply if a newer
    version of the CRD is available. Empty if no update needs to be applied.
r   r(   r   N)
r   r   r   r   r   r   r    
crManifestcrdManifestr   r   r   r   r;  r;  Q  s)     $$Q'*%%a(+r   r;  c                   <    \ rS rSrSr\R                  " S5      rSrg)-GenerateMembershipRBACRoleBindingYAMLResponsei`  zuResponse for GenerateRBACRoleBindingYAML.

Fields:
  roleBindingsYaml: a yaml text blob including the RBAC policies.
r   r   N)	r   r   r   r   r   r   r    roleBindingsYamlr   r   r   r   r?  r?  `  s     **1-r   r?  c                   <    \ rS rSrSr\R                  " S5      rSrg)GetReferenceRequestij  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    r   r   r   r   r   rB  rB  j  s     
		q	!$r   rB  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      r	Sr
g)
GkeClusterix  a  GkeCluster contains information specific to GKE clusters.

Fields:
  clusterMissing: Output only. If cluster_missing is set then it denotes
    that the GKE cluster no longer exists in the GKE Control Plane.
  resourceLink: Immutable. Self-link of the Google Cloud resource for the
    GKE cluster. For example: //container.googleapis.com/projects/my-
    project/locations/us-west1-a/clusters/my-cluster Zonal clusters are also
    supported.
r   r(   r   Nr   r   r   r   r   r   r8   clusterMissingr    r!   r   r   r   r   rE  rE  x  s)    	 ))!,.&&q),r   rE  c                       \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " S5      r\R                  " SSS9rS	rg
)-GkehubOrganizationsLocationsFleetsListRequesti  a  A GkehubOrganizationsLocationsFleetsListRequest object.

Fields:
  pageSize: Optional. The maximum number of fleets to return. The service
    may return fewer than this value. If unspecified, at most 200 fleets
    will be returned. The maximum value is 1000; values above 1000 will be
    coerced to 1000.
  pageToken: Optional. A page token, received from a previous `ListFleets`
    call. Provide this to retrieve the subsequent page. When paginating, all
    other parameters provided to `ListFleets` must match the call that
    provided the page token.
  parent: Required. The organization or project to list for Fleets under, in
    the format `organizations/*/locations/*` or `projects/*/locations/*`.
r   r   r(   r0   Trequiredr   Nr   r   r   r   r   r   r   r   r   pageSizer    	pageTokenr  r   r   r   r   rI  rI    I     ##Ay/@/@/F/FG(##A&)  T2&r   rI  c                       \ rS rSrSr\R                  " SS5      r\R                  " S5      r	\R                  " SSS9r
\R                  " S	5      rS
rg),GkehubProjectsLocationsFeaturesCreateRequesti  aQ  A GkehubProjectsLocationsFeaturesCreateRequest 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/*`.
  requestId: A request ID to identify requests. Specify a unique request ID
    so that if you must retry your request, the server will know to ignore
    the request if it has already been completed. The server will guarantee
    that for at least 60 minutes after the first request. For example,
    consider a situation where you make an initial request and the request
    times out. If you make the request again with the same request ID, the
    server can check if original operation with the same request ID was
    received, and if so, will ignore the second request. This prevents
    clients from accidentally creating duplicate commitments. The request ID
    must be a valid UUID with the exception that zero UUID is not supported
    (00000000-0000-0000-0000-000000000000).
r  r   r(   r0   TrJ  r?   r   N)r   r   r   r   r   r   r   featurer    	featureIdr  r  r   r   r   r   rQ  rQ    sM    ( ""9a0'##A&)  T2&##A&)r   rQ  c                       \ rS rSrSr\R                  " S5      r\R                  " SSS9r	\R                  " S5      r
Srg	)
,GkehubProjectsLocationsFeaturesDeleteRequesti  a  A GkehubProjectsLocationsFeaturesDeleteRequest 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/*/features/*`.
  requestId: Optional. A request ID to identify requests. Specify a unique
    request ID so that if you must retry your request, the server will know
    to ignore the request if it has already been completed. The server will
    guarantee that for at least 60 minutes after the first request. For
    example, consider a situation where you make an initial request and the
    request times out. If you make the request again with the same request
    ID, the server can check if original operation with the same request ID
    was received, and if so, will ignore the second request. This prevents
    clients from accidentally creating duplicate commitments. The request ID
    must be a valid UUID with the exception that zero UUID is not supported
    (00000000-0000-0000-0000-000000000000).
r   r(   TrJ  r0   r   Nr   r   r   r   r   r   r8   forcer    r   r  r   r   r   r   rU  rU    ;    * 
 
 
#%			q4	0$##A&)r   rU  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(   TrJ  r   Nr   r   r   r   r   r   r   r   r   options_requestedPolicyVersionr    resourcer   r   r   r   rZ  rZ    :    * $-#9#9!YEVEVE\E\#] ""1t4(r   rZ  c                   ^    \ rS rSrSr\R                  " SSS9r\R                  " S5      r	Sr
g)	)GkehubProjectsLocationsFeaturesGetRequesti  a  A GkehubProjectsLocationsFeaturesGetRequest object.

Fields:
  name: Required. The Feature resource name in the format
    `projects/*/locations/*/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   TrJ  r(   r   N)r   r   r   r   r   r   r    r   r8   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)*GkehubProjectsLocationsFeaturesListRequesti  a8  A GkehubProjectsLocationsFeaturesListRequest 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" - 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/*`.
  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(   r0   r   r?   r@   TrJ  rA   r   N)r   r   r   r   r   r   r    filterorderByr   r   r   rM  rN  r  r8   ra  r   r   r   r   rc  rc    sz    2   #&!!!$'##Ay/@/@/F/FG(##A&)  T2&"//2r   rc  c                       \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	\R                  " S5      r
\R                  " S	5      rS
rg)+GkehubProjectsLocationsFeaturesPatchRequesti  a  A GkehubProjectsLocationsFeaturesPatchRequest object.

Fields:
  feature: A Feature resource to be passed as the request body.
  name: Required. The Feature resource name in the format
    `projects/*/locations/*/features/*`.
  requestId: A request ID to identify requests. Specify a unique request ID
    so that if you must retry your request, the server will know to ignore
    the request if it has already been completed. The server will guarantee
    that for at least 60 minutes after the first request. For example,
    consider a situation where you make an initial request and the request
    times out. If you make the request again with the same request ID, the
    server can check if original operation with the same request ID was
    received, and if so, will ignore the second request. This prevents
    clients from accidentally creating duplicate commitments. The request ID
    must be a valid UUID with the exception that zero UUID is not supported
    (00000000-0000-0000-0000-000000000000).
  updateMask: Mask of fields to update.
r  r   r(   TrJ  r0   r?   r   N)r   r   r   r   r   r   r   rR  r    r   r  
updateMaskr   r   r   r   rg  rg    sM    ( ""9a0'			q4	0$##A&)$$Q'*r   rg  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
2GkehubProjectsLocationsFeaturesSetIamPolicyRequesti:  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   TrJ  SetIamPolicyRequestr(   r   Nr   r   r   r   r   r   r    r]  r   setIamPolicyRequestr   r   r   r   rj  rj  :  /    	 ""1t4(!../DaHr   rj  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
8GkehubProjectsLocationsFeaturesTestIamPermissionsRequestiJ  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   TrJ  TestIamPermissionsRequestr(   r   Nr   r   r   r   r   r   r    r]  r   testIamPermissionsRequestr   r   r   r   rp  rp  J  0    	 ""1t4('445PRSTr   rp  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
*GkehubProjectsLocationsFleetsCreateRequestiZ  a  A GkehubProjectsLocationsFleetsCreateRequest object.

Fields:
  fleet: A Fleet resource to be passed as the request body.
  parent: Required. The parent (project and location) where the Fleet will
    be created. Specified in the format `projects/*/locations/*`.
r  r   r(   TrJ  r   N)r   r   r   r   r   r   r   fleetr    r  r   r   r   r   rv  rv  Z  s-     
 
 !
,%  T2&r   rv  c                   :    \ rS rSrSr\R                  " SSS9rSrg)*GkehubProjectsLocationsFleetsDeleteRequestig  zA GkehubProjectsLocationsFleetsDeleteRequest object.

Fields:
  name: Required. The Fleet resource name in the format
    `projects/*/locations/*/fleets/*`.
r   TrJ  r   NrC  r   r   r   ry  ry  g       
		q4	0$r   ry  c                   :    \ rS rSrSr\R                  " SSS9rSrg)'GkehubProjectsLocationsFleetsGetRequestir  zA GkehubProjectsLocationsFleetsGetRequest object.

Fields:
  name: Required. The Fleet resource name in the format
    `projects/*/locations/*/fleets/*`.
r   TrJ  r   NrC  r   r   r   r|  r|  r  rz  r   r|  c                       \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " S5      r\R                  " SSS9rS	rg
)(GkehubProjectsLocationsFleetsListRequesti}  a  A GkehubProjectsLocationsFleetsListRequest object.

Fields:
  pageSize: Optional. The maximum number of fleets to return. The service
    may return fewer than this value. If unspecified, at most 200 fleets
    will be returned. The maximum value is 1000; values above 1000 will be
    coerced to 1000.
  pageToken: Optional. A page token, received from a previous `ListFleets`
    call. Provide this to retrieve the subsequent page. When paginating, all
    other parameters provided to `ListFleets` must match the call that
    provided the page token.
  parent: Required. The organization or project to list for Fleets under, in
    the format `organizations/*/locations/*` or `projects/*/locations/*`.
r   r   r(   r0   TrJ  r   NrL  r   r   r   r~  r~  }  rO  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
))GkehubProjectsLocationsFleetsPatchRequesti  a  A GkehubProjectsLocationsFleetsPatchRequest object.

Fields:
  fleet: A Fleet resource to be passed as the request body.
  name: Output only. The full, unique resource name of this fleet in the
    format of `projects/{project}/locations/{location}/fleets/{fleet}`. Each
    Google Cloud project can have at most one fleet resource, named
    "default".
  updateMask: Required. The fields to be updated;
r  r   r(   TrJ  r0   r   N)r   r   r   r   r   r   r   rw  r    r   rh  r   r   r   r   r  r    s=    	 
 
 !
,%			q4	0$$$Q'*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   TrJ  r   NrC  r   r   r   r  r         
		q4	0$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(   r0   r?   rJ  r@   r   rA   r   N)r   r   r   r   r   r   r    extraLocationTypesrd  r8   includeUnrevealedLocationsr   r   r   r   rM  rN  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5      r	\R                  " SSS9r
S	rg
)7GkehubProjectsLocationsMembershipsBindingsCreateRequesti  a  A GkehubProjectsLocationsMembershipsBindingsCreateRequest object.

Fields:
  membershipBinding: A MembershipBinding resource to be passed as the
    request body.
  membershipBindingId: Required. The ID to use for the MembershipBinding.
  parent: Required. The parent (project and location) where the
    MembershipBinding will be created. Specified in the format
    `projects/*/locations/*/memberships/*`.
MembershipBindingr   r(   r0   TrJ  r   N)r   r   r   r   r   r   r   membershipBindingr    membershipBindingIdr  r   r   r   r   r  r    s@    	  ,,-@!D!--a0  T2&r   r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)7GkehubProjectsLocationsMembershipsBindingsDeleteRequesti  zA GkehubProjectsLocationsMembershipsBindingsDeleteRequest object.

Fields:
  name: Required. The MembershipBinding resource name in the format
    `projects/*/locations/*/memberships/*/bindings/*`.
r   TrJ  r   NrC  r   r   r   r  r    rz  r   r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)4GkehubProjectsLocationsMembershipsBindingsGetRequesti  zA GkehubProjectsLocationsMembershipsBindingsGetRequest object.

Fields:
  name: Required. The MembershipBinding resource name in the format
    `projects/*/locations/*/memberships/*/bindings/*`.
r   TrJ  r   NrC  r   r   r   r  r    rz  r   r  c                       \ rS rSrSr\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " S5      r\R                  " SSS	9rS
rg)5GkehubProjectsLocationsMembershipsBindingsListRequesti  a  A GkehubProjectsLocationsMembershipsBindingsListRequest object.

Fields:
  filter: Optional. Lists MembershipBindings that match the filter
    expression, following the syntax outlined in https://google.aip.dev/160.
  pageSize: Optional. 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: Optional. Token returned by previous call to
    `ListMembershipBindings` which specifies the position in the list from
    where to continue listing the resources.
  parent: Required. The parent Membership for which the MembershipBindings
    will be listed. Specified in the format
    `projects/*/locations/*/memberships/*`.
r   r(   r   r0   r?   TrJ  r   Nr   r   r   r   r   r   r    rd  r   r   r   rM  rN  r  r   r   r   r   r  r    sY        #&##Ay/@/@/F/FG(##A&)  T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
)6GkehubProjectsLocationsMembershipsBindingsPatchRequesti  ay  A GkehubProjectsLocationsMembershipsBindingsPatchRequest object.

Fields:
  membershipBinding: A MembershipBinding resource to be passed as the
    request body.
  name: The resource name for the membershipbinding itself `projects/{projec
    t}/locations/{location}/memberships/{membership}/bindings/{membershipbin
    ding}`
  updateMask: Required. The fields to be updated.
r  r   r(   TrJ  r0   r   N)r   r   r   r   r   r   r   r  r    r   rh  r   r   r   r   r  r    s?    	  ,,-@!D			q4	0$$$Q'*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
\R                  " S	5      rS
rg)/GkehubProjectsLocationsMembershipsCreateRequesti  a  A GkehubProjectsLocationsMembershipsCreateRequest object.

Fields:
  membership: A Membership resource to be passed as the request body.
  membershipId: Required. Client chosen ID for the membership.
    `membership_id` must be a valid RFC 1123 compliant DNS label: 1. At most
    63 characters in length 2. It must consist of lower case alphanumeric
    characters or `-` 3. It must start and end with an alphanumeric
    character Which can be expressed as the regex:
    `[a-z0-9]([-a-z0-9]*[a-z0-9])?`, with a maximum length of 63 characters.
  parent: Required. The parent (project and location) where the Memberships
    will be created. Specified in the format `projects/*/locations/*`.
  requestId: Optional. A request ID to identify requests. Specify a unique
    request ID so that if you must retry your request, the server will know
    to ignore the request if it has already been completed. The server will
    guarantee that for at least 60 minutes after the first request. For
    example, consider a situation where you make an initial request and the
    request times out. If you make the request again with the same request
    ID, the server can check if original operation with the same request ID
    was received, and if so, will ignore the second request. This prevents
    clients from accidentally creating duplicate commitments. The request ID
    must be a valid UUID with the exception that zero UUID is not supported
    (00000000-0000-0000-0000-000000000000).

Membershipr   r(   r0   TrJ  r?   r   N)r   r   r   r   r   r   r   r   r    membershipIdr  r  r   r   r   r   r  r    sM    2 %%lA6*&&q),  T2&##A&)r   r  c                       \ rS rSrSr\R                  " S5      r\R                  " SSS9r	\R                  " S5      r
Srg	)
/GkehubProjectsLocationsMembershipsDeleteRequesti7  a|  A GkehubProjectsLocationsMembershipsDeleteRequest object.

Fields:
  force: Optional. If set to true, any subresource from this Membership will
    also be deleted. Otherwise, the request will only work if the Membership
    has no subresource.
  name: Required. The Membership resource name in the format
    `projects/*/locations/*/memberships/*`.
  requestId: Optional. A request ID to identify requests. Specify a unique
    request ID so that if you must retry your request, the server will know
    to ignore the request if it has already been completed. The server will
    guarantee that for at least 60 minutes after the first request. For
    example, consider a situation where you make an initial request and the
    request times out. If you make the request again with the same request
    ID, the server can check if original operation with the same request ID
    was received, and if so, will ignore the second request. This prevents
    clients from accidentally creating duplicate commitments. The request ID
    must be a valid UUID with the exception that zero UUID is not supported
    (00000000-0000-0000-0000-000000000000).
r   r(   TrJ  r0   r   NrV  r   r   r   r  r  7  rX  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S	S
9r\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                  " S5      rSrg)@GkehubProjectsLocationsMembershipsGenerateConnectManifestRequestiR  a  A GkehubProjectsLocationsMembershipsGenerateConnectManifestRequest
object.

Fields:
  cpuRequest: Optional. To customize the CPU requested for the Connect Agent
    resource.
  imagePullSecretContent: Optional. The image pull secret content for the
    registry, if not public.
  isUpgrade: Optional. If true, generate the resources for upgrade only.
    Some resources generated only for installation (e.g. secrets) will be
    excluded.
  memLimit: Optional. To customize the memory limit for the Connect Agent
    resource.
  memRequest: Optional. To customize the memory requested for the Connect
    Agent resource.
  name: Required. The Membership resource name the Agent will associate
    with, in the format `projects/*/locations/*/memberships/*`.
  namespace: Optional. Namespace for GKE Connect agent resources. Defaults
    to `gke-connect`. The Connect Agent is authorized automatically when run
    in the default namespace. Otherwise, explicit authorization must be
    granted with an additional IAM binding.
  proxy: Optional. URI of a proxy if connectivity from the agent to
    gkeconnect.googleapis.com requires the use of a proxy. Format must be in
    the form `http(s)://{proxy_address}`, depending on the HTTP/HTTPS
    protocol supported by the proxy. This will direct the connect agent's
    outbound traffic through a HTTP(S) proxy.
  registry: Optional. The registry to fetch the connect agent image from.
    Defaults to gcr.io/gkeconnect.
  version: Optional. The Connect agent version to use. Defaults to the most
    current version.
r   r(   r0   r?   r@   rA   TrJ  r   r  r
  r  r   N)r   r   r   r   r   r   r    r  rD   imagePullSecretContentr8   	isUpgradememLimit
memRequestr   	namespaceproxyregistryr   r   r   r   r   r  r  R  s    @ $$Q'*$//2$$Q')""1%($$Q'*			q4	0$##A&)


q
!%""1%(!!"%'r   r  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " SSS9r	Sr
g	)
DGkehubProjectsLocationsMembershipsGenerateExclusivityManifestRequesti  a  A GkehubProjectsLocationsMembershipsGenerateExclusivityManifestRequest
object.

Fields:
  crManifest: Optional. The YAML manifest of the membership CR retrieved by
    `kubectl get memberships membership`. Leave empty if the resource does
    not exist.
  crdManifest: Optional. The YAML manifest of the membership CRD retrieved
    by `kubectl get customresourcedefinitions membership`. Leave empty if
    the resource does not exist.
  name: Required. The Membership resource name in the format
    `projects/*/locations/*/memberships/*`.
r   r(   r0   TrJ  r   N)r   r   r   r   r   r   r    r<  r=  r   r   r   r   r   r  r    s;     $$Q'*%%a(+			q4	0$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	)
5GkehubProjectsLocationsMembershipsGetIamPolicyRequesti  aA  A GkehubProjectsLocationsMembershipsGetIamPolicyRequest 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(   TrJ  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),GkehubProjectsLocationsMembershipsGetRequesti  zA GkehubProjectsLocationsMembershipsGetRequest object.

Fields:
  name: Required. The Membership resource name in the format
    `projects/*/locations/*/memberships/*`.
r   TrJ  r   NrC  r   r   r   r  r    rz  r   r  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " S5      r\R                  " SS	S
9rSrg)2GkehubProjectsLocationsMembershipsListAdminRequesti  a4  A GkehubProjectsLocationsMembershipsListAdminRequest object.

Fields:
  filter: Optional. Lists Memberships of admin clusters that match the
    filter expression.
  orderBy: Optional. One or more fields to compare and use to sort the
    output. See https://google.aip.dev/132#ordering.
  pageSize: Optional. 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: Optional. Token returned by previous call to
    `ListAdminClusterMemberships` which specifies the position in the list
    from where to continue listing the resources.
  parent: Required. The parent (project and location) where the Memberships
    of admin cluster will be listed. Specified in the format
    `projects/*/locations/*`.
r   r(   r0   r   r?   r@   TrJ  r   Nr   r   r   r   r   r   r    rd  re  r   r   r   rM  rN  r  r   r   r   r   r  r    si    $   #&!!!$'##Ay/@/@/F/FG(##A&)  T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Srg)-GkehubProjectsLocationsMembershipsListRequesti  a  A GkehubProjectsLocationsMembershipsListRequest object.

Fields:
  filter: Optional. Lists Memberships that match the filter expression,
    following the syntax outlined in https://google.aip.dev/160. Examples: -
    Name is `bar` in project `foo-proj` and location `global`: name =
    "projects/foo-proj/locations/global/membership/bar" - Memberships that
    have a label called `foo`: labels.foo:* - Memberships that have a label
    called `foo` whose value is `bar`: labels.foo = bar - Memberships in the
    CREATING state: state = CREATING
  orderBy: Optional. One or more fields to compare and use to sort the
    output. See https://google.aip.dev/132#ordering.
  pageSize: Optional. 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: Optional. Token returned by previous call to `ListMemberships`
    which specifies the position in the list from where to continue listing
    the resources.
  parent: Required. The parent (project and location) where the Memberships
    will be listed. Specified in the format `projects/*/locations/*`.
    `projects/*/locations/-` list memberships in all the regions.
r   r(   r0   r   r?   r@   TrJ  r   Nr  r   r   r   r  r    si    .   #&!!!$'##Ay/@/@/F/FG(##A&)  T2&r   r  c                       \ rS rSrSr\R                  " SS5      r\R                  " S5      r	\R                  " S\R                  R                  S9r\R                  " S5      r\R                  " S	S
S9rSrg)5GkehubProjectsLocationsMembershipsListSelectedRequesti  a}  A GkehubProjectsLocationsMembershipsListSelectedRequest object.

Fields:
  clusterSelector: A ClusterSelector resource to be passed as the request
    body.
  orderBy: Optional. One or more fields to compare and use to sort the
    output. See https://google.aip.dev/132#ordering.
  pageSize: Optional. 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: Optional. Token returned by previous call to
    `ListMembershipsWithSelector` which specifies the position in the list
    from where to continue listing the resources.
  parent: Required. The parent (project and location) where the Memberships
    will be listed. Specified in the format
    `projects/[project_id]/locations/[location]`.
    `projects/[project_id]/locations/-` list memberships in all the regions.
r   r   r(   r0   r   r?   r@   TrJ  r   N)r   r   r   r   r   r   r   clusterSelectorr    re  r   r   r   rM  rN  r  r   r   r   r   r  r    sl    & **+<a@/!!!$'##Ay/@/@/F/FG(##A&)  T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
\R                  " S	5      rS
rg).GkehubProjectsLocationsMembershipsPatchRequesti  aA  A GkehubProjectsLocationsMembershipsPatchRequest object.

Fields:
  membership: A Membership resource to be passed as the request body.
  name: Required. The Membership resource name in the format
    `projects/*/locations/*/memberships/*`.
  requestId: Optional. A request ID to identify requests. Specify a unique
    request ID so that if you must retry your request, the server will know
    to ignore the request if it has already been completed. The server will
    guarantee that for at least 60 minutes after the first request. For
    example, consider a situation where you make an initial request and the
    request times out. If you make the request again with the same request
    ID, the server can check if original operation with the same request ID
    was received, and if so, will ignore the second request. This prevents
    clients from accidentally creating duplicate commitments. The request ID
    must be a valid UUID with the exception that zero UUID is not supported
    (00000000-0000-0000-0000-000000000000).
  updateMask: Required. Mask of fields to update.
r  r   r(   TrJ  r0   r?   r   N)r   r   r   r   r   r   r   r   r    r   r  rh  r   r   r   r   r  r    sM    ( %%lA6*			q4	0$##A&)$$Q'*r   r  c                       \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	\R                  " S5      r
S	rg
)?GkehubProjectsLocationsMembershipsRbacrolebindingsCreateRequesti'  a  A GkehubProjectsLocationsMembershipsRbacrolebindingsCreateRequest
object.

Fields:
  parent: Required. The parent (project and location) where the
    RBACRoleBinding will be created. Specified in the format
    `projects/*/locations/*/memberships/*`.
  rBACRoleBinding: A RBACRoleBinding resource to be passed as the request
    body.
  rbacrolebindingId: Required. Client chosen ID for the RBACRoleBinding.
    `rbacrolebinding_id` must be a valid RFC 1123 compliant DNS label: 1. At
    most 63 characters in length 2. It must consist of lower case
    alphanumeric characters or `-` 3. It must start and end with an
    alphanumeric character Which can be expressed as the regex:
    `[a-z0-9]([-a-z0-9]*[a-z0-9])?`, with a maximum length of 63 characters.
r   TrJ  RBACRoleBindingr(   r0   r   Nr   r   r   r   r   r   r    r  r   rBACRoleBindingrbacrolebindingIdr   r   r   r   r  r  '  ?    "   T2&**+<a@/++A.r   r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)?GkehubProjectsLocationsMembershipsRbacrolebindingsDeleteRequesti>  zA GkehubProjectsLocationsMembershipsRbacrolebindingsDeleteRequest
object.

Fields:
  name: Required. The RBACRoleBinding resource name in the format
    `projects/*/locations/*/memberships/*/rbacrolebindings/*`.
r   TrJ  r   NrC  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S5      r	\R                  " S5      r
S	rg
)^GkehubProjectsLocationsMembershipsRbacrolebindingsGenerateMembershipRBACRoleBindingYAMLRequestiJ  a  A GkehubProjectsLocationsMembershipsRbacrolebindingsGenerateMembershipRB
ACRoleBindingYAMLRequest object.

Fields:
  parent: Required. The parent (project and location) where the
    RBACRoleBinding will be created. Specified in the format
    `projects/*/locations/*/memberships/*`.
  rBACRoleBinding: A RBACRoleBinding resource to be passed as the request
    body.
  rbacrolebindingId: Required. Client chosen ID for the RBACRoleBinding.
    `rbacrolebinding_id` must be a valid RFC 1123 compliant DNS label: 1. At
    most 63 characters in length 2. It must consist of lower case
    alphanumeric characters or `-` 3. It must start and end with an
    alphanumeric character Which can be expressed as the regex:
    `[a-z0-9]([-a-z0-9]*[a-z0-9])?`, with a maximum length of 63 characters.
r   TrJ  r  r(   r0   r   Nr  r   r   r   r  r  J  r  r   r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)<GkehubProjectsLocationsMembershipsRbacrolebindingsGetRequestia  zA GkehubProjectsLocationsMembershipsRbacrolebindingsGetRequest object.

Fields:
  name: Required. The RBACRoleBinding resource name in the format
    `projects/*/locations/*/memberships/*/rbacrolebindings/*`.
r   TrJ  r   NrC  r   r   r   r  r  a  rz  r   r  c                       \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " S5      r\R                  " SSS9rS	rg
)=GkehubProjectsLocationsMembershipsRbacrolebindingsListRequestil  ab  A GkehubProjectsLocationsMembershipsRbacrolebindingsListRequest object.

Fields:
  pageSize: Optional. 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: Optional. Token returned by previous call to
    `ListMembershipRBACRoleBindings` 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/*/memberships/*`.
r   r   r(   r0   TrJ  r   NrL  r   r   r   r  r  l  I     ##Ay/@/@/F/FG(##A&)  T2&r   r  c                       \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	\R                  " S5      r
S	rg
)>GkehubProjectsLocationsMembershipsRbacrolebindingsPatchRequesti  a  A GkehubProjectsLocationsMembershipsRbacrolebindingsPatchRequest object.

Fields:
  name: The resource name for the rbacrolebinding `projects/{project}/locati
    ons/{location}/scopes/{scope}/rbacrolebindings/{rbacrolebinding}` or `pr
    ojects/{project}/locations/{location}/memberships/{membership}/rbacroleb
    indings/{rbacrolebinding}`
  rBACRoleBinding: A RBACRoleBinding resource to be passed as the request
    body.
  updateMask: Required. The fields to be updated.
r   TrJ  r  r(   r0   r   Nr   r   r   r   r   r   r    r   r   r  rh  r   r   r   r   r  r    >    
 
		q4	0$**+<a@/$$Q'*r   r  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
5GkehubProjectsLocationsMembershipsSetIamPolicyRequesti  aq  A GkehubProjectsLocationsMembershipsSetIamPolicyRequest 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   TrJ  rk  r(   r   Nrl  r   r   r   r  r    rn  r   r  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
;GkehubProjectsLocationsMembershipsTestIamPermissionsRequesti  a  A GkehubProjectsLocationsMembershipsTestIamPermissionsRequest 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   TrJ  rq  r(   r   Nrr  r   r   r   r  r    rt  r   r  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
7GkehubProjectsLocationsMembershipsValidateCreateRequesti  aR  A GkehubProjectsLocationsMembershipsValidateCreateRequest object.

Fields:
  parent: Required. The parent (project and location) where the Memberships
    will be created. Specified in the format `projects/*/locations/*`.
  validateCreateMembershipRequest: A ValidateCreateMembershipRequest
    resource to be passed as the request body.
r   TrJ  ValidateCreateMembershipRequestr(   r   N)r   r   r   r   r   r   r    r  r   validateCreateMembershipRequestr   r   r   r   r  r    s0       T2&$-$:$:;\^_$`!r   r  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " SSS9r	Sr
g	)
<GkehubProjectsLocationsMembershipsValidateExclusivityRequesti  a  A GkehubProjectsLocationsMembershipsValidateExclusivityRequest object.

Fields:
  crManifest: Optional. The YAML of the membership CR in the cluster. Empty
    if the membership CR does not exist.
  intendedMembership: Required. The intended membership name under the
    `parent`. This method only does validation in anticipation of a
    CreateMembership call with the same name.
  parent: Required. The parent (project and location) where the Memberships
    will be created. Specified in the format `projects/*/locations/*`.
r   r(   r0   TrJ  r   N)r   r   r   r   r   r   r    r<  intendedMembershipr  r   r   r   r   r  r    s<    
 $$Q'* ,,Q/  T2&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
).GkehubProjectsLocationsNamespacesCreateRequesti  a  A GkehubProjectsLocationsNamespacesCreateRequest object.

Fields:
  namespace: A Namespace resource to be passed as the request body.
  namespaceId: Required. Client chosen ID for the Namespace. `namespace_id`
    must be a valid RFC 1123 compliant DNS label: 1. At most 63 characters
    in length 2. It must consist of lower case alphanumeric characters or
    `-` 3. It must start and end with an alphanumeric character Which can be
    expressed as the regex: `[a-z0-9]([-a-z0-9]*[a-z0-9])?`, with a maximum
    length of 63 characters.
  parent: Required. The parent (project and location) where the Namespace
    will be created. Specified in the format `projects/*/locations/*`.
	Namespacer   r(   r0   TrJ  r   N)r   r   r   r   r   r   r   r  r    namespaceIdr  r   r   r   r   r  r    s=     $$[!4)%%a(+  T2&r   r  c                   :    \ rS rSrSr\R                  " SSS9rSrg).GkehubProjectsLocationsNamespacesDeleteRequesti  zA GkehubProjectsLocationsNamespacesDeleteRequest object.

Fields:
  name: Required. The Namespace resource name in the format
    `projects/*/locations/*/namespaces/*`.
r   TrJ  r   NrC  r   r   r   r  r    rz  r   r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)+GkehubProjectsLocationsNamespacesGetRequesti  zA GkehubProjectsLocationsNamespacesGetRequest object.

Fields:
  name: Required. The Namespace resource name in the format
    `projects/*/locations/*/namespaces/*`.
r   TrJ  r   NrC  r   r   r   r  r    rz  r   r  c                       \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " S5      r\R                  " SSS9rS	rg
),GkehubProjectsLocationsNamespacesListRequesti  a-  A GkehubProjectsLocationsNamespacesListRequest object.

Fields:
  pageSize: Optional. 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: Optional. 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/*`.
r   r   r(   r0   TrJ  r   NrL  r   r   r   r  r    I     ##Ay/@/@/F/FG(##A&)  T2&r   r  c                       \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	\R                  " S5      r
S	rg
)-GkehubProjectsLocationsNamespacesPatchRequesti  a(  A GkehubProjectsLocationsNamespacesPatchRequest object.

Fields:
  name: The resource name for the namespace
    `projects/{project}/locations/{location}/namespaces/{namespace}`
  namespace: A Namespace resource to be passed as the request body.
  updateMask: Required. The fields to be updated.
r   TrJ  r  r(   r0   r   Nr   r   r   r   r   r   r    r   r   r  rh  r   r   r   r   r  r    =     
		q4	0$$$[!4)$$Q'*r   r  c                       \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	\R                  " S5      r
S	rg
)>GkehubProjectsLocationsNamespacesRbacrolebindingsCreateRequesti  a  A GkehubProjectsLocationsNamespacesRbacrolebindingsCreateRequest object.

Fields:
  parent: Required. The parent (project and location) where the
    RBACRoleBinding will be created. Specified in the format
    `projects/*/locations/*/namespaces/*`.
  rBACRoleBinding: A RBACRoleBinding resource to be passed as the request
    body.
  rbacrolebindingId: Required. Client chosen ID for the RBACRoleBinding.
    `rbacrolebinding_id` must be a valid RFC 1123 compliant DNS label: 1. At
    most 63 characters in length 2. It must consist of lower case
    alphanumeric characters or `-` 3. It must start and end with an
    alphanumeric character Which can be expressed as the regex:
    `[a-z0-9]([-a-z0-9]*[a-z0-9])?`, with a maximum length of 63 characters.
r   TrJ  r  r(   r0   r   Nr  r   r   r   r  r    ?        T2&**+<a@/++A.r   r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)>GkehubProjectsLocationsNamespacesRbacrolebindingsDeleteRequesti4  zA GkehubProjectsLocationsNamespacesRbacrolebindingsDeleteRequest object.

Fields:
  name: Required. The RBACRoleBinding resource name in the format
    `projects/*/locations/*/namespaces/*/rbacrolebindings/*`.
r   TrJ  r   NrC  r   r   r   r  r  4  rz  r   r  c                   :    \ rS rSrSr\R                  " SSS9rSrg);GkehubProjectsLocationsNamespacesRbacrolebindingsGetRequesti?  zA GkehubProjectsLocationsNamespacesRbacrolebindingsGetRequest object.

Fields:
  name: Required. The RBACRoleBinding resource name in the format
    `projects/*/locations/*/namespaces/*/rbacrolebindings/*`.
r   TrJ  r   NrC  r   r   r   r  r  ?  rz  r   r  c                       \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " S5      r\R                  " SSS9rS	rg
)<GkehubProjectsLocationsNamespacesRbacrolebindingsListRequestiJ  aV  A GkehubProjectsLocationsNamespacesRbacrolebindingsListRequest object.

Fields:
  pageSize: Optional. 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: Optional. Token returned by previous call to
    `ListRBACRoleBindings` 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/*/namespaces/*`.
r   r   r(   r0   TrJ  r   NrL  r   r   r   r  r  J  r  r   r  c                       \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	\R                  " S5      r
S	rg
)=GkehubProjectsLocationsNamespacesRbacrolebindingsPatchRequesti^  a  A GkehubProjectsLocationsNamespacesRbacrolebindingsPatchRequest object.

Fields:
  name: The resource name for the rbacrolebinding `projects/{project}/locati
    ons/{location}/scopes/{scope}/rbacrolebindings/{rbacrolebinding}` or `pr
    ojects/{project}/locations/{location}/memberships/{membership}/rbacroleb
    indings/{rbacrolebinding}`
  rBACRoleBinding: A RBACRoleBinding resource to be passed as the request
    body.
  updateMask: Required. The fields to be updated.
r   TrJ  r  r(   r0   r   Nr  r   r   r   r  r  ^  r  r   r  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
.GkehubProjectsLocationsOperationsCancelRequestip  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.
rj   r   r(   TrJ  r   N)r   r   r   r   r   r   r   cancelOperationRequestr    r   r   r   r   r   r  r  p  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   TrJ  r   NrC  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)+GkehubProjectsLocationsOperationsGetRequesti  zkA GkehubProjectsLocationsOperationsGetRequest object.

Fields:
  name: The name of the operation resource.
r   TrJ  r   NrC  r   r   r   r  r    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(   TrJ  r0   r   r?   r@   r   N)r   r   r   r   r   r   r    rd  r   r   r   r   rM  rN  r8   ra  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SS9r\R                  " SS5      r	\R                  " S5      r
S	rg
)4GkehubProjectsLocationsRolloutSequencesCreateRequesti  a  A GkehubProjectsLocationsRolloutSequencesCreateRequest object.

Fields:
  parent: Required. The parent resource where this rollout sequence will be
    created. projects/{project}/locations/{location}
  rolloutSequence: A RolloutSequence resource to be passed as the request
    body.
  rolloutSequenceId: Required. User provided identifier that is used as part
    of the resource name; must conform to RFC-1034 and additionally restrict
    to lower-cased letters. This comes out roughly to: /^a-z+[a-z0-9]$/
r   TrJ  RolloutSequencer(   r0   r   N)r   r   r   r   r   r   r    r  r   rolloutSequencerolloutSequenceIdr   r   r   r   r  r    s?    
   T2&**+<a@/++A.r   r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)4GkehubProjectsLocationsRolloutSequencesDeleteRequesti  zA GkehubProjectsLocationsRolloutSequencesDeleteRequest object.

Fields:
  name: Required. The name of the rollout sequence to delete. projects/{proj
    ect}/locations/{location}/rolloutSequences/{rollout_sequence}
r   TrJ  r   NrC  r   r   r   r  r    rz  r   r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)1GkehubProjectsLocationsRolloutSequencesGetRequesti  zA GkehubProjectsLocationsRolloutSequencesGetRequest object.

Fields:
  name: Required. The name of the rollout sequence to retrieve. projects/{pr
    oject}/locations/{location}/rolloutSequences/{rollout_sequence}
r   TrJ  r   NrC  r   r   r   r  r    rz  r   r  c                       \ rS rSrSr\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " S5      r\R                  " SSS	9rS
rg)2GkehubProjectsLocationsRolloutSequencesListRequesti  ar  A GkehubProjectsLocationsRolloutSequencesListRequest object.

Fields:
  filter: Optional. Lists Rollout Sequences that match the filter
    expression, following the syntax outlined in https://google.aip.dev/160.
  pageSize: Optional. The maximum number of rollout sequences to return. The
    service may return fewer than this value. If unspecified, at most 50
    rollout sequences will be returned. The maximum value is 1000; values
    above 1000 will be coerced to 1000.
  pageToken: Optional. A page token, received from a previous
    `ListRolloutSequences` call. Provide this to retrieve the subsequent
    page. When paginating, all other parameters provided to
    `ListRolloutSequences` must match the call that provided the page token.
  parent: Required. The parent, which owns this collection of rollout
    sequences. Format: projects/{project}/locations/{location}
r   r(   r   r0   r?   TrJ  r   Nr  r   r   r   r  r    Y    "   #&##Ay/@/@/F/FG(##A&)  T2&r   r  c                       \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	\R                  " S5      r
S	rg
)3GkehubProjectsLocationsRolloutSequencesPatchRequesti  aW  A GkehubProjectsLocationsRolloutSequencesPatchRequest object.

Fields:
  name: Identifier. Name of the rollout sequence in the format of:
    projects/{PROJECT_ID}/locations/global/rolloutSequences/{NAME}
  rolloutSequence: A RolloutSequence resource to be passed as the request
    body.
  updateMask: Optional. The list of fields to update.
r   TrJ  r  r(   r0   r   N)r   r   r   r   r   r   r    r   r   r  rh  r   r   r   r   r  r    s>     
		q4	0$**+<a@/$$Q'*r   r  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
,GkehubProjectsLocationsRolloutsCancelRequesti  a  A GkehubProjectsLocationsRolloutsCancelRequest object.

Fields:
  cancelRolloutRequest: A CancelRolloutRequest resource to be passed as the
    request body.
  name: Required. The name of the rollout to cancel.
    projects/{project}/locations/{location}/rollouts/{rollout}
rl   r   r(   TrJ  r   N)r   r   r   r   r   r   r   cancelRolloutRequestr    r   r   r   r   r   r  r    s/     #//0FJ			q4	0$r   r  c                       \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	\R                  " S5      r
S	rg
),GkehubProjectsLocationsRolloutsCreateRequesti  a  A GkehubProjectsLocationsRolloutsCreateRequest object.

Fields:
  parent: Required. The parent resource where this rollout will be created.
    projects/{project}/locations/{location}
  rollout: A Rollout resource to be passed as the request body.
  rolloutId: Required. User provided identifier that is used as part of the
    resource name; must conform to RFC-1034 and additionally restrict to
    lower-cased letters. This comes out roughly to: /^a-z+[a-z0-9]$/
r   TrJ  Rolloutr(   r0   r   N)r   r   r   r   r   r   r    r  r   rollout	rolloutIdr   r   r   r   r	  r	    s=    	   T2&""9a0'##A&)r   r	  c                   ^    \ rS rSrSr\R                  " SSS9r\R                  " S5      rSr	g)	,GkehubProjectsLocationsRolloutsDeleteRequesti  a  A GkehubProjectsLocationsRolloutsDeleteRequest object.

Fields:
  name: Required. The name of the rollout to delete.
    projects/{project}/locations/{location}/rollouts/{rollout}
  requestId: Optional. A request ID to identify requests. Specify a unique
    request ID so that if you must retry your request, the server will know
    to ignore the request if it has already been completed. The server will
    guarantee that for at least 60 minutes after the first request. For
    example, consider a situation where you make an initial request and the
    request times out. If you make the request again with the same request
    ID, the server can check if original operation with the same request ID
    was received, and if so, will ignore the second request. This prevents
    clients from accidentally creating duplicate commitments. The request ID
    must be a valid UUID with the exception that zero UUID is not supported
    (00000000-0000-0000-0000-000000000000).
r   TrJ  r(   r   Nr  r   r   r   r  r    s+    $ 
		q4	0$##A&)r   r  c                   :    \ rS rSrSr\R                  " SSS9rSrg))GkehubProjectsLocationsRolloutsGetRequesti/  zA GkehubProjectsLocationsRolloutsGetRequest object.

Fields:
  name: Required. The name of the rollout to retrieve.
    projects/{project}/locations/{location}/rollouts/{rollout}
r   TrJ  r   NrC  r   r   r   r  r  /  rz  r   r  c                       \ rS rSrSr\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " S5      r\R                  " SSS	9rS
rg)*GkehubProjectsLocationsRolloutsListRequesti:  a   A GkehubProjectsLocationsRolloutsListRequest object.

Fields:
  filter: Optional. Lists Rollouts that match the filter expression,
    following the syntax outlined in https://google.aip.dev/160.
  pageSize: The maximum number of rollout to return. The service may return
    fewer than this value. If unspecified, at most 50 rollouts will be
    returned. The maximum value is 1000; values above 1000 will be coerced
    to 1000.
  pageToken: A page token, received from a previous `ListRollouts` call.
    Provide this to retrieve the subsequent page. When paginating, all other
    parameters provided to `ListRollouts` must match the call that provided
    the page token.
  parent: Required. The parent, which owns this collection of rollout.
    Format: projects/{project}/locations/{location}
r   r(   r   r0   r?   TrJ  r   Nr  r   r   r   r  r  :  r  r   r  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
+GkehubProjectsLocationsRolloutsPauseRequestiR  a  A GkehubProjectsLocationsRolloutsPauseRequest object.

Fields:
  name: Required. The name of the rollout to pause.
    projects/{project}/locations/{location}/rollouts/{rollout}
  pauseRolloutRequest: A PauseRolloutRequest resource to be passed as the
    request body.
r   TrJ  PauseRolloutRequestr(   r   N)r   r   r   r   r   r   r    r   r   pauseRolloutRequestr   r   r   r   r  r  R  s/     
		q4	0$!../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	)
,GkehubProjectsLocationsRolloutsResumeRequesti`  a  A GkehubProjectsLocationsRolloutsResumeRequest object.

Fields:
  name: Required. The name of the rollout to resume.
    projects/{project}/locations/{location}/rollouts/{rollout}
  resumeRolloutRequest: A ResumeRolloutRequest resource to be passed as the
    request body.
r   TrJ  ResumeRolloutRequestr(   r   N)r   r   r   r   r   r   r    r   r   resumeRolloutRequestr   r   r   r   r  r  `  s/     
		q4	0$"//0FJr   r  c                       \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	\R                  " S5      r
S	rg
)*GkehubProjectsLocationsScopesCreateRequestin  aZ  A GkehubProjectsLocationsScopesCreateRequest object.

Fields:
  parent: Required. The parent (project and location) where the Scope will
    be created. Specified in the format `projects/*/locations/*`.
  scope: A Scope resource to be passed as the request body.
  scopeId: Required. Client chosen ID for the Scope. `scope_id` must be a
    ????
r   TrJ  Scoper(   r0   r   N)r   r   r   r   r   r   r    r  r   scopescopeIdr   r   r   r   r  r  n  s=       T2&

 
 !
,%!!!$'r   r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)*GkehubProjectsLocationsScopesDeleteRequesti~  zA GkehubProjectsLocationsScopesDeleteRequest object.

Fields:
  name: Required. The Scope resource name in the format
    `projects/*/locations/*/scopes/*`.
r   TrJ  r   NrC  r   r   r   r!  r!  ~  rz  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	)
0GkehubProjectsLocationsScopesGetIamPolicyRequesti  a<  A GkehubProjectsLocationsScopesGetIamPolicyRequest 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(   TrJ  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)'GkehubProjectsLocationsScopesGetRequesti  zA GkehubProjectsLocationsScopesGetRequest object.

Fields:
  name: Required. The Scope resource name in the format
    `projects/*/locations/*/scopes/*`.
r   TrJ  r   NrC  r   r   r   r%  r%    rz  r   r%  c                       \ rS rSrSr\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " S5      r\R                  " SSS	9rS
rg)3GkehubProjectsLocationsScopesListMembershipsRequesti  a  A GkehubProjectsLocationsScopesListMembershipsRequest object.

Fields:
  filter: Optional. Lists Memberships that match the filter expression,
    following the syntax outlined in https://google.aip.dev/160. Currently,
    filtering can be done only based on Memberships's `name`, `labels`,
    `create_time`, `update_time`, and `unique_id`.
  pageSize: Optional. 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. Pagination is currently not supported;
    therefore, setting this field does not have any impact for now.
  pageToken: Optional. Token returned by previous call to
    `ListBoundMemberships` which specifies the position in the list from
    where to continue listing the resources.
  scopeName: Required. Name of the Scope, in the format
    `projects/*/locations/global/scopes/*`, to which the Memberships are
    bound.
r   r(   r   r0   r?   TrJ  r   N)r   r   r   r   r   r   r    rd  r   r   r   rM  rN  	scopeNamer   r   r   r   r'  r'    sY    &   #&##Ay/@/@/F/FG(##A&)##A5)r   r'  c                       \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " S5      r\R                  " SSS9rS	rg
)1GkehubProjectsLocationsScopesListPermittedRequesti  a6  A GkehubProjectsLocationsScopesListPermittedRequest object.

Fields:
  pageSize: Optional. 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: Optional. Token returned by previous call to
    `ListPermittedScopes` which specifies the position in the list from
    where to continue listing the resources.
  parent: Required. The parent (project and location) where the Scope will
    be listed. Specified in the format `projects/*/locations/*`.
r   r   r(   r0   TrJ  r   NrL  r   r   r   r*  r*    r  r   r*  c                       \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " S5      r\R                  " SSS9rS	rg
)(GkehubProjectsLocationsScopesListRequesti  a$  A GkehubProjectsLocationsScopesListRequest object.

Fields:
  pageSize: Optional. 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: Optional. Token returned by previous call to `ListScopes` which
    specifies the position in the list from where to continue listing the
    resources.
  parent: Required. The parent (project and location) where the Scope will
    be listed. Specified in the format `projects/*/locations/*`.
r   r   r(   r0   TrJ  r   NrL  r   r   r   r,  r,    r  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
)4GkehubProjectsLocationsScopesNamespacesCreateRequesti  a  A GkehubProjectsLocationsScopesNamespacesCreateRequest object.

Fields:
  namespace: A Namespace resource to be passed as the request body.
  parent: Required. The parent (project and location) where the Namespace
    will be created. Specified in the format
    `projects/*/locations/*/scopes/*`.
  scopeNamespaceId: Required. Client chosen ID for the Namespace.
    `namespace_id` must be a valid RFC 1123 compliant DNS label: 1. At most
    63 characters in length 2. It must consist of lower case alphanumeric
    characters or `-` 3. It must start and end with an alphanumeric
    character Which can be expressed as the regex:
    `[a-z0-9]([-a-z0-9]*[a-z0-9])?`, with a maximum length of 63 characters.
r  r   r(   TrJ  r0   r   N)r   r   r   r   r   r   r   r  r    r  scopeNamespaceIdr   r   r   r   r.  r.    s>     $$[!4)  T2&**1-r   r.  c                   :    \ rS rSrSr\R                  " SSS9rSrg)4GkehubProjectsLocationsScopesNamespacesDeleteRequesti  zA GkehubProjectsLocationsScopesNamespacesDeleteRequest object.

Fields:
  name: Required. The Namespace resource name in the format
    `projects/*/locations/*/scopes/*/namespaces/*`.
r   TrJ  r   NrC  r   r   r   r1  r1    rz  r   r1  c                   :    \ rS rSrSr\R                  " SSS9rSrg)1GkehubProjectsLocationsScopesNamespacesGetRequesti  zA GkehubProjectsLocationsScopesNamespacesGetRequest object.

Fields:
  name: Required. The Namespace resource name in the format
    `projects/*/locations/*/scopes/*/namespaces/*`.
r   TrJ  r   NrC  r   r   r   r3  r3    rz  r   r3  c                       \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " S5      r\R                  " SSS9rS	rg
)2GkehubProjectsLocationsScopesNamespacesListRequesti  a@  A GkehubProjectsLocationsScopesNamespacesListRequest object.

Fields:
  pageSize: Optional. 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: Optional. 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/*/scopes/*`.
r   r   r(   r0   TrJ  r   NrL  r   r   r   r5  r5    r  r   r5  c                       \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	\R                  " S5      r
S	rg
)3GkehubProjectsLocationsScopesNamespacesPatchRequesti-  a.  A GkehubProjectsLocationsScopesNamespacesPatchRequest object.

Fields:
  name: The resource name for the namespace
    `projects/{project}/locations/{location}/namespaces/{namespace}`
  namespace: A Namespace resource to be passed as the request body.
  updateMask: Required. The fields to be updated.
r   TrJ  r  r(   r0   r   Nr  r   r   r   r7  r7  -  r  r   r7  c                       \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	\R                  " S5      r
S	rg
))GkehubProjectsLocationsScopesPatchRequesti<  a  A GkehubProjectsLocationsScopesPatchRequest object.

Fields:
  name: The resource name for the scope
    `projects/{project}/locations/{location}/scopes/{scope}`
  scope: A Scope resource to be passed as the request body.
  updateMask: Required. The fields to be updated.
r   TrJ  r  r(   r0   r   N)r   r   r   r   r   r   r    r   r   r  rh  r   r   r   r   r9  r9  <  s=     
		q4	0$

 
 !
,%$$Q'*r   r9  c                       \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	\R                  " S5      r
S	rg
):GkehubProjectsLocationsScopesRbacrolebindingsCreateRequestiK  a  A GkehubProjectsLocationsScopesRbacrolebindingsCreateRequest object.

Fields:
  parent: Required. The parent (project and location) where the
    RBACRoleBinding will be created. Specified in the format
    `projects/*/locations/*/scopes/*`.
  rBACRoleBinding: A RBACRoleBinding resource to be passed as the request
    body.
  rbacrolebindingId: Required. Client chosen ID for the RBACRoleBinding.
    `rbacrolebinding_id` must be a valid RFC 1123 compliant DNS label: 1. At
    most 63 characters in length 2. It must consist of lower case
    alphanumeric characters or `-` 3. It must start and end with an
    alphanumeric character Which can be expressed as the regex:
    `[a-z0-9]([-a-z0-9]*[a-z0-9])?`, with a maximum length of 63 characters.
r   TrJ  r  r(   r0   r   Nr  r   r   r   r;  r;  K  r  r   r;  c                   :    \ rS rSrSr\R                  " SSS9rSrg):GkehubProjectsLocationsScopesRbacrolebindingsDeleteRequestia  zA GkehubProjectsLocationsScopesRbacrolebindingsDeleteRequest object.

Fields:
  name: Required. The RBACRoleBinding resource name in the format
    `projects/*/locations/*/scopes/*/rbacrolebindings/*`.
r   TrJ  r   NrC  r   r   r   r=  r=  a  rz  r   r=  c                   :    \ rS rSrSr\R                  " SSS9rSrg)7GkehubProjectsLocationsScopesRbacrolebindingsGetRequestil  zA GkehubProjectsLocationsScopesRbacrolebindingsGetRequest object.

Fields:
  name: Required. The RBACRoleBinding resource name in the format
    `projects/*/locations/*/scopes/*/rbacrolebindings/*`.
r   TrJ  r   NrC  r   r   r   r?  r?  l  rz  r   r?  c                       \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " S5      r\R                  " SSS9rS	rg
)8GkehubProjectsLocationsScopesRbacrolebindingsListRequestiw  aS  A GkehubProjectsLocationsScopesRbacrolebindingsListRequest object.

Fields:
  pageSize: Optional. 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: Optional. Token returned by previous call to
    `ListScopeRBACRoleBindings` 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/*/scopes/*`.
r   r   r(   r0   TrJ  r   NrL  r   r   r   rA  rA  w  r  r   rA  c                       \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	\R                  " S5      r
S	rg
)9GkehubProjectsLocationsScopesRbacrolebindingsPatchRequesti  a  A GkehubProjectsLocationsScopesRbacrolebindingsPatchRequest object.

Fields:
  name: The resource name for the rbacrolebinding `projects/{project}/locati
    ons/{location}/scopes/{scope}/rbacrolebindings/{rbacrolebinding}` or `pr
    ojects/{project}/locations/{location}/memberships/{membership}/rbacroleb
    indings/{rbacrolebinding}`
  rBACRoleBinding: A RBACRoleBinding resource to be passed as the request
    body.
  updateMask: Required. The fields to be updated.
r   TrJ  r  r(   r0   r   Nr  r   r   r   rC  rC    r  r   rC  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
0GkehubProjectsLocationsScopesSetIamPolicyRequesti  al  A GkehubProjectsLocationsScopesSetIamPolicyRequest 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   TrJ  rk  r(   r   Nrl  r   r   r   rE  rE    rn  r   rE  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
6GkehubProjectsLocationsScopesTestIamPermissionsRequesti  a  A GkehubProjectsLocationsScopesTestIamPermissionsRequest 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   TrJ  rq  r(   r   Nrr  r   r   r   rG  rG    rt  r   rG  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   extra_types.JsonValuer(   r   Nr   r   r   r   r   rN    r  r   r   r   Tr&   r   Nr   r   r   r   DetailsValueListEntryrK    4    		AY.. 	A %112FTXYr   rQ  r   r   r(   Tr&   r0   r   N)r   r   r   r   r   r   r   r   r   rQ  r   r   r   r   r   detailsr    rp  r   r   r   r   rI  rI    s|    & !!"89Zi// Z :Z2 
		9+<+<+B+B	C$""#:AM'!!!$'r   rI  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)HelloWorldFeatureSamplei  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),HelloWorldFeatureSample.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   ThirdValueValuesEnumrW    s     OEFr   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	)
"HelloWorldFeatureSample.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)5HelloWorldFeatureSample.FifthValue.AdditionalPropertyi  zAn additional property for a FifthValue object.

Fields:
  key: Name of the additional property.
  value: A extra_types.JsonValue attribute.
r   rP  r(   r   Nr   r   r   r   r   r_    r  r   r   r   Tr&   r   Nr   r   r   r   
FifthValuer]    4    	AY.. 	A %112FTXYr   r`  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
"HelloWorldFeatureSample.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)5HelloWorldFeatureSample.NinthValue.AdditionalPropertyi6  zAn additional property for a NinthValue object.

Fields:
  key: Name of the additional property.
  value: A HelloWorldFooBar attribute.
r   HelloWorldFooBarr(   r   Nr   r   r   r   r   re  6  r  r   r   r   Tr&   r   Nr   r   r   r   
NinthValuerc  +  s2    	<Y.. 	< %112FTXYr   rg  rf  r   Tr&   r(   r0   r?   r@   rA   r   r   r  r
  r   N)r   r   r   r   r   r   r6   r[  r   r   r   r`  rg  r   eighthfifthr    firstfourthninthr   r   r   secondseventhsixthr:   thirdr   r   r   r   rU  rU    s#   *
Y^^ 
 !!"89Z9$$ Z :Z0 !!"89Z9$$ Z :Z. !!"4a$G&

 
 q
1%



"%  #&

 
 q
1%!!!Y->->-D-DE&!!!$'

 
 
#%


4a
8%r   rU  c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)r  iN  a  **Hello World**: The Hub-wide 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   rU  r(   r   Nr   r   r   r   r   r   r    customConfigr   featureSampler   r   r   r   r  r  N  ,     &&q),(()BAF-r   r  c                       \ rS rSrSrSrg)r#  i\  zK**Hello World**: An empty state left as an example Hub-wide Feature
state.
r   Nr   r   r   r   r#  r#  \  r0  r   r#  c                       \ rS rSrSr\R                  " S5      r\R                  " S\R                  R                  S9rSrg)rf  ic  zUNested Message.

Fields:
  first: A string attribute.
  second: A integer attribute.
r   r(   r   r   N)r   r   r   r   r   r   r    rj  r   r   r   rm  r   r   r   r   rf  rf  c  s7     


"%!!!Y->->-D-DE&r   rf  c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)r-  io  a  **Hello World**: The membership-specific input for HelloWorld feature.

Fields:
  customConfig: Custom config for individual memberships. This should be a
    textpb string.
  featureSample: Message to hold fields to use in feature e2e create/mutate
    testing.
r   rU  r(   r   Nrr  r   r   r   r-  r-  o  ru  r   r-  c                       \ rS rSrSrSrg)HelloWorldMembershipStatei}  zV**Hello World**: An empty state left as an example membership-specific
Feature state.
r   Nr   r   r   r   rz  rz  }  r0  r   rz  c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)HelloWorldScopeSpeci  a  **Hello World**: The scope-specific input for HelloWorld feature.

Fields:
  customConfig: Custom config for individual memberships. This should be a
    textpb string.
  featureSample: Message to hold fields to use in feature e2e create/mutate
    testing.
r   rU  r(   r   Nrr  r   r   r   r|  r|    ru  r   r|  c                       \ rS rSrSrSrg)HelloWorldScopeStatei  zQ**Hello World**: An empty state left as an example scope-specific
Feature state.
r   Nr   r   r   r   r~  r~    r0  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)IdentityServiceAuthMethodi  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: LDAP specific configuration.
  name: Identifier for auth config.
  oidcConfig: OIDC specific configuration.
  proxy: Proxy server address to use for auth method.
  samlConfig: SAML specific configuration.
IdentityServiceAzureADConfigr   IdentityServiceGoogleConfigr(   IdentityServiceLdapConfigr0   r?   IdentityServiceOidcConfigr@   rA   IdentityServiceSamlConfigr   r   N)r   r   r   r   r   r   r   azureadConfiggoogleConfig
ldapConfigr    r   
oidcConfigr  
samlConfigr   r   r   r   r  r    s     (()GK-''(EqI,%%&A1E*			q	!$%%&A1E*



"%%%&A1E*r   r  c                      \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S5      r
\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                  " S	5      rS
rg)r  i  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(   r0   r?   r@   rA   r   r   N)r   r   r   r   r   r   r    clientIdclientSecretrD   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\R                  " S5      r	Sr
g)"IdentityServiceDiagnosticInterfacei  a-  Configuration options for the AIS diagnostic interface.

Fields:
  enabled: Determines whether to enable the diagnostic interface.
  expirationTime: Determines the expiration time of the diagnostic interface
    enablement. When reached, requests to the interface would be
    automatically rejected.
r   r(   r   N)r   r   r   r   r   r   r8   r  r    expirationTimer   r   r   r   r  r    s)     ""1%'((+.r   r  c                   <    \ rS rSrSr\R                  " S5      rSrg)r  i  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   r8   disabler   r   r   r   r  r    s     ""1%'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)IdentityServiceGroupConfigi  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(   r0   r   N)r   r   r   r   r   r   r    baseDnrd  idAttributer   r   r   r   r  r    s9        #&  #&%%a(+r   r  c                   b    \ rS rSrSr\R                  " SS5      r\R                  " S5      r	Sr
g)%IdentityServiceIdentityServiceOptionsi  zHolds non-protocol-related configuration options.

Fields:
  diagnosticInterface: Configuration options for the AIS diagnostic
    interface.
  sessionDuration: Determines the lifespan of STS tokens issued by Anthos
    Identity Service.
r  r   r(   r   N)r   r   r   r   r   r   r   diagnosticInterfacer    sessionDurationr   r   r   r   r  r    s.     "../SUVW))!,/r   r  c                       \ rS rSrSr\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r	\R                  " S	S
5      r
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   IdentityServiceServerConfigr(   #IdentityServiceServiceAccountConfigr0   IdentityServiceUserConfigr?   r   N)r   r   r   r   r   r   r   r  serverserviceAccountuserr   r   r   r   r  r    sV     
 
 !=q
A%!!"?C&))*OQRS.			 ;Q	?$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  z**Anthos Identity Service**: Configuration for a single Membership.

Fields:
  authMethods: A member may support multiple auth methods.
  identityServiceOptions: Optional. non-protocol-related configuration
    options.
r  r   Tr&   r  r(   r   N)
r   r   r   r   r   r   r   authMethodsidentityServiceOptionsr   r   r   r   r.  r.    s4     &&'BAPTU+$112Y[\]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)IdentityServiceMembershipStatei)  a  **Anthos Identity Service**: State for a single Membership.

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: Last reconciled membership configuration
  state: Deployment state on this member
c                   $    \ rS rSrSrSrSrSrSrg)3IdentityServiceMembershipState.StateValueValuesEnumi7  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   r  r  r  r   r   r   r   r   r  7  s     $% 	
BEr   r   r   r(   r.  r0   r?   r   N)r   r   r   r   r   r   r6   r   r    failureReasoninstalledVersionr   memberConfigr:   r   r   r   r   r   r  r  )  s`    
Y^^ 
 ''*-**1-''(GK,


4a
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\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  iI  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(   r0   r?   r@   rA   r   r  r
  r  r  r  r  r  r   N)r   r   r   r   r   r   r    certificateAuthorityDatar  r  r8   deployCloudConsoleProxyenableAccessTokenrD   r  extraParamsgroupPrefixgroupsClaim	issuerUrir  r   r  
userPrefixr   r   r   r   r  r  I  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\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)r  ir  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	)
/IdentityServiceSamlConfig.AttributeMappingValuei  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)BIdentityServiceSamlConfig.AttributeMappingValue.AdditionalPropertyi  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    r  r   r   r   Tr&   r   Nr   r   r   r   AttributeMappingValuer    s2     	'Y.. 	' %112FTXYr   r  r   r(   r0   r?   Tr&   r@   rA   r   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   r  r  r  s     D !!"89Zi// Z :Z< ++,CQG%%a(+))!,/!*!6!6q4!H ,,Q/$003''*-$$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  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(   r0   r   N)r   r   r   r   r   r   rD   r  r    connectionTypehostr   r   r   r   r  r    s:     '11!4((+.			q	!$r   r  c                   >    \ rS rSrSr\R                  " SS5      rSrg)r  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.
$IdentityServiceSimpleBindCredentialsr   r   N)	r   r   r   r   r   r   r   simpleBindCredentialsr   r   r   r   r  r    s     $001WYZ[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(   r0   r   N)r   r   r   r   r   r   r    dnrD   encryptedPasswordpasswordr   r   r   r   r  r    s:    	 Q"**1-""1%(r   r  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S5      r	\R                  " S5      r
Srg)	r  i  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(   r0   r?   r   N)r   r   r   r   r   r   r    r  rd  r  loginAttributer   r   r   r   r  r    sI    .   #&  #&%%a(+((+.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\R                  R                  S9r\R                  " S5      r\R                  " S	5      r\R                  " S
\R                  R                  S9rSrg)KubernetesMetadatai  ac  KubernetesMetadata provides informational metadata for Memberships
representing Kubernetes clusters.

Fields:
  distribution: Output only. Distribution as identified by GKE Hub from
    Kubernetes node resources.
  kubernetesApiServerVersion: Output only. Kubernetes API server version
    string as reported by `/version`.
  memoryMb: Output only. The total memory capacity as reported by the sum of
    all Kubernetes nodes resources, defined in MB.
  nodeCount: Output only. Node count as reported by Kubernetes nodes
    resources.
  nodeProviderId: Output only. Node providerID as reported by the first node
    in the list of nodes on the Kubernetes endpoint. On Kubernetes platforms
    that support zero-node clusters (like GKE-on-GCP), the node_count will
    be zero and the node_provider_id will be empty.
  updateTime: Output only. The time at which these details were last
    updated. This update_time is different from the Membership-level
    update_time since EndpointDetails are updated internally for API
    consumers.
  vcpuCount: Output only. vCPU count as reported by Kubernetes nodes
    resources.
r   r(   r0   r   r?   r@   rA   r   r   N)r   r   r   r   r   r   r    distributionrC  r   r   r   memoryMb	nodeCountnodeProviderIdr   	vcpuCountr   r   r   r   r  r    s    0 &&q),(44Q7##Ay/@/@/F/FG($$Q	0A0A0G0GH)((+.$$Q'*$$Q	0A0A0G0GH)r   r  c                       \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	\R                  " SSSS9r
\R                  " S	S
5      rSrg)KubernetesResourcei/  a  KubernetesResource contains the YAML manifests and configuration for
Membership Kubernetes resources in the cluster. After CreateMembership or
UpdateMembership, these resources should be re-applied in the cluster.

Fields:
  connectResources: Output only. The Kubernetes resources for installing the
    GKE Connect agent This field is only populated in the Membership
    returned from a successful long-running operation from CreateMembership
    or UpdateMembership. It is not populated during normal GetMembership or
    ListMemberships requests. To get the resource manifest after the initial
    registration, the caller should make a UpdateMembership call with an
    empty field mask.
  membershipCrManifest: Input only. The YAML representation of the
    Membership CR. This field is ignored for GKE clusters where Hub can read
    the CR directly. Callers should provide the CR that is currently present
    in the cluster during CreateMembership or UpdateMembership, or leave
    this field empty if none exists. The CR manifest is used to validate the
    cluster has not been registered with another Membership.
  membershipResources: Output only. Additional Kubernetes resources that
    need to be applied to the cluster after Membership creation, and after
    every update. This field is only populated in the Membership returned
    from a successful long-running operation from CreateMembership or
    UpdateMembership. It is not populated during normal GetMembership or
    ListMemberships requests. To get the resource manifest after the initial
    registration, the caller should make a UpdateMembership call with an
    empty field mask.
  resourceOptions: Optional. Options for Kubernetes resource generation.
ResourceManifestr   Tr&   r(   r0   ResourceOptionsr?   r   N)r   r   r   r   r   r   r   connectResourcesr    membershipCrManifestmembershipResourcesresourceOptionsr   r   r   r   r  r  /  sY    : ++,>DQ"..q1!../A1tT**+<a@/r   r  c                       \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	\R                  " SSS9r
S	rg
)#ListAdminClusterMembershipsResponseiS  a  Response message for the `GkeHub.ListAdminClusterMemberships` method.

Fields:
  adminClusterMemberships: The list of matching Memberships of admin
    clusters.
  nextPageToken: A token to request the next page of resources from the
    `ListAdminClusterMemberships` method. The value of an empty string means
    that there are no more resources to return.
  unreachable: List of locations that could not be reached while fetching
    this list.
r  r   Tr&   r(   r0   r   N)r   r   r   r   r   r   r   adminClusterMembershipsr    nextPageTokenr  r   r   r   r   r  r  S  s@    
 &22<TR''*-%%a$7+r   r  c                       \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	\R                  " SSS9r
S	rg
)ListBoundMembershipsResponseie  a  List of Memberships bound to a Scope.

Fields:
  memberships: The list of Memberships bound to the given Scope.
  nextPageToken: A token to request the next page of resources from the
    `ListBoundMemberships` method. The value of an empty string means that
    there are no more resources to return.
  unreachable: List of locations that could not be reached while fetching
    this list.
r  r   Tr&   r(   r0   r   N)r   r   r   r   r   r   r   membershipsr    r  r  r   r   r   r   r  r  e  s?    	 &&|QF+''*-%%a$7+r   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
ListFeaturesResponseiv  a!  Response message for the `GkeHub.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    r  r   	resourcesr   r   r   r   r  r  v  s-     ''*-$$YDA)r   r  c                   `    \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	Sr
g	)
ListFleetsResponsei  a%  Response message for the `GkeHub.ListFleetsResponse` method.

Fields:
  fleets: The list of matching fleets.
  nextPageToken: A token, which can be sent as `page_token` to retrieve the
    next page. If this field is omitted, there are no subsequent pages. The
    token is only valid for 1h.
r  r   Tr&   r(   r   N)r   r   r   r   r   r   r   fleetsr    r  r   r   r   r   r  r    s-     !!'1t<&''*-r   r  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    r  r   r   r   r   r  r    s-     $$ZTB)''*-r   r  c                       \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	\R                  " SSS9r
S	rg
)ListMembershipBindingsResponsei  at  List of MembershipBindings.

Fields:
  membershipBindings: The list of membership_bindings
  nextPageToken: A token to request the next page of resources from the
    `ListMembershipBindings` method. The value of an empty string means that
    there are no more resources to return.
  unreachable: List of locations that could not be reached while fetching
    this list.
r  r   Tr&   r(   r0   r   N)r   r   r   r   r   r   r   membershipBindingsr    r  r  r   r   r   r   r  r    sA    	 !--.A1tT''*-%%a$7+r   r  c                       \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	\R                  " SSS9r
S	rg
)&ListMembershipRBACRoleBindingsResponsei  a  List of Membership RBACRoleBindings.

Fields:
  nextPageToken: A token to request the next page of resources from the
    `ListMembershipRBACRoleBindings` method. The value of an empty string
    means that there are no more resources to return.
  rbacrolebindings: The list of Membership RBACRoleBindings.
  unreachable: List of locations that could not be reached while fetching
    this list.
r   r  r(   Tr&   r0   r   N)r   r   r   r   r   r   r    r  r   rbacrolebindingsr  r   r   r   r   r  r    sA    	 ''*-++,=q4P%%a$7+r   r  c                       \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	\R                  " SSS9r
S	rg
)ListMembershipsResponsei  a  Response message for the `GkeHub.ListMemberships` method.

Fields:
  nextPageToken: A token to request the next page of resources from the
    `ListMemberships` method. The value of an empty string means that there
    are no more resources to return.
  resources: The list of matching Memberships.
  unreachable: List of locations that could not be reached while fetching
    this list.
r   r  r(   Tr&   r0   r   Nr   r   r   r   r   r   r    r  r   r  r  r   r   r   r   r  r    ?    	 ''*-$$\1tD)%%a$7+r   r  c                   `    \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	Sr
g	)
ListNamespacesResponsei  a  List of fleet namespaces.

Fields:
  namespaces: The list of fleet namespaces
  nextPageToken: A token to request the next page of resources from the
    `ListNamespaces` method. The value of an empty string means that there
    are no more resources to return.
r  r   Tr&   r(   r   N)r   r   r   r   r   r   r   
namespacesr    r  r   r   r   r   r  r    s-     %%k1tD*''*-r   r  c                       \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	\R                  " SSS9r
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&   r0   r   N)r   r   r   r   r   r   r    r  r   
operationsr  r   r   r   r   r   r     s?    
 ''*-%%k1tD*%%a$7+r   r   c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
ListPermittedScopesResponsei  a  List of permitted Scopes.

Fields:
  nextPageToken: A token to request the next page of resources from the
    `ListPermittedScopes` method. The value of an empty string means that
    there are no more resources to return.
  scopes: The list of permitted Scopes
r   r  r(   Tr&   r   Nr   r   r   r   r   r   r    r  r   r   r   r   r   r   r  r    -     ''*-!!'1t<&r   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
ListRBACRoleBindingsResponsei   a  List of RBACRoleBindings.

Fields:
  nextPageToken: A token to request the next page of resources from the
    `ListRBACRoleBindings` method. The value of an empty string means that
    there are no more resources to return.
  rbacrolebindings: The list of RBACRoleBindings
r   r  r(   Tr&   r   Nr   r   r   r   r   r   r    r  r   r  r   r   r   r   r  r     /     ''*-++,=q4P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)	ListReferencesRequesti  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(   r0   r   NrL  r   r   r   r  r    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    r  r   
referencesr   r   r   r   r  r  "  s-     ''*-%%k1tD*r   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
ListRolloutSequencesResponsei/  a  Response message for listing rollout sequences.

Fields:
  nextPageToken: A token, which can be sent as `page_token` to retrieve the
    next page. If this field is omitted, there are no subsequent pages.
  rolloutSequences: The rollout sequences from the specified parent
    resource.
r   r  r(   Tr&   r   N)r   r   r   r   r   r   r    r  r   rolloutSequencesr   r   r   r   r  r  /  r
  r   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
ListRolloutsResponsei=  a  Response message for listing rollouts.

Fields:
  nextPageToken: A token, which can be sent as `page_token` to retrieve the
    next page. If this field is omitted, there are no subsequent pages.
  rollouts: The rollouts from the specified parent resource.
r   r
  r(   Tr&   r   N)r   r   r   r   r   r   r    r  r   rolloutsr   r   r   r   r  r  =  s-     ''*-##Iq4@(r   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
ListScopeNamespacesResponseiJ  a  List of fleet namespaces.

Fields:
  nextPageToken: A token to request the next page of resources from the
    `ListNamespaces` method. The value of an empty string means that there
    are no more resources to return.
  scopeNamespaces: The list of fleet namespaces
r   r  r(   Tr&   r   N)r   r   r   r   r   r   r    r  r   scopeNamespacesr   r   r   r   r  r  J  s-     ''*-**;DI/r   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
!ListScopeRBACRoleBindingsResponseiX  a$  List of Scope RBACRoleBindings.

Fields:
  nextPageToken: A token to request the next page of resources from the
    `ListScopeRBACRoleBindings` method. The value of an empty string means
    that there are no more resources to return.
  rbacrolebindings: The list of Scope RBACRoleBindings.
r   r  r(   Tr&   r   Nr	  r   r   r   r  r  X  r
  r   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
ListScopesResponseif  zList of Scopes.

Fields:
  nextPageToken: A token to request the next page of resources from the
    `ListScopes` method. The value of an empty string means that there are
    no more resources to return.
  scopes: The list of Scopes
r   r  r(   Tr&   r   Nr  r   r   r   r  r  f  r  r   r  c                       \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	\R                  " SSS9r
S	rg
)ListSelectedMembershipsResponseit  a  List of Memberships matching the given cluster selector.

Fields:
  nextPageToken: A token to request the next page of resources from the
    `ListMembershipsWithSelector` method. The value of an empty string means
    that there are no more resources to return.
  resources: The list of selected Memberships.
  unreachable: List of locations that could not be reached while fetching
    this list.
r   r  r(   Tr&   r0   r   Nr  r   r   r   r  r  t  r  r   r  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)r  i  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   r#    r  r   r   r   Tr&   r   Nr   r   r   r   r  r!    2    	'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   rP  r(   r   Nr   r   r   r   r   r(    r  r   r   r   Tr&   r   Nr   r   r   r   MetadataValuer&    rR  r   r*  r   r(   r0   r?   r@   r   N)r   r   r   r   r   r   r   r   r   r  r*  r    r  r   r  
locationIdmetadatar   r   r   r   r   r  r    s    * !!"89ZI%% Z :Z0 !!"89Zi'' Z :Z2 %%a(+!!-3&$$Q'*##OQ7(			q	!$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	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.
rq   r   r  r(   r  r0   r   N)r   r   r   r   r   r   r   
cloudAuditcounter
dataAccessr   r   r   r   r.  r.    sB     %%&91=*""#3Q7'%%&91=*r   r.  c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)ManagedRolloutConfigi  aI  The configuration used for the Rollout. Waves are assigned
automatically.

Fields:
  soakDuration: Optional. Default soak time before starting the next wave.
    The soak_duration in the stages overrides this value on a per-wave
    basis.
  uiprRolloutConfig: Optional. The UIPR specific configuration used for the
    Rollout.
r   UIPRRolloutConfigr(   r   N)r   r   r   r   r   r   r    soakDurationr   uiprRolloutConfigr   r   r   r   r3  r3    s-    	 &&q),,,-@!Dr   r3  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	5       " S
 S\R                  5      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5      r\R&                  " S5      r\R                  " SS5      r\R&                  " S5      r\R"                  " SS5      r\R                  " SS5      r\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!5      r!\R&                  " S"5      r"S#r#g$)%r  i  a  Membership contains information about a member cluster.

Enums:
  ClusterTierValueValuesEnum: Output only. The tier of the cluster.
  InfrastructureTypeValueValuesEnum: Optional. The infrastructure type this
    Membership is running on.
  MembershipTypeValueValuesEnum: Output only. The type of the membership.

Messages:
  LabelsValue: Optional. Labels for this membership. These labels are not
    leveraged by multi-cluster features, instead, we prefer cluster labels,
    which can be set on GKE cluster or other cluster types.
  PlatformLabelsValue: Output only. The labels of the cluster, coming from
    the platform api For example, a GKE cluster object labels are replicated
    here. This field is used by multi-cluster features as the source of
    labels and they ignore the membership labels (the `labels` field)

Fields:
  authority: Optional. How to identify workloads from this Membership. See
    the documentation on Workload Identity for more details:
    https://cloud.google.com/kubernetes-engine/docs/how-to/workload-identity
  clusterTier: Output only. The tier of the cluster.
  createTime: Output only. When the Membership was created.
  deleteTime: Output only. When the Membership was deleted.
  description: Output only. Description of this membership, limited to 63
    characters. Must match the regex: `a-zA-Z0-9*` This field is present for
    legacy purposes.
  endpoint: Optional. Endpoint information to reach this member.
  externalId: Optional. An externally-generated and managed ID for this
    Membership. This ID may be modified after creation, but this is not
    recommended. The ID must match the regex: `a-zA-Z0-9*` If this
    Membership represents a Kubernetes cluster, this value should be set to
    the UID of the `kube-system` namespace object.
  infrastructureType: Optional. The infrastructure type this Membership is
    running on.
  labels: Optional. Labels for this membership. These labels are not
    leveraged by multi-cluster features, instead, we prefer cluster labels,
    which can be set on GKE cluster or other cluster types.
  lastConnectionTime: Output only. For clusters using Connect, the timestamp
    of the most recent connection established with Google Cloud. This time
    is updated every several minutes, not continuously. For clusters that do
    not use GKE Connect, or that have never connected successfully, this
    field will be unset.
  membershipType: Output only. The type of the membership.
  monitoringConfig: Optional. The monitoring config information for this
    membership.
  name: Output only. The full, unique name of this Membership resource in
    the format `projects/*/locations/*/memberships/{membership_id}`, set
    during creation. `membership_id` must be a valid RFC 1123 compliant DNS
    label: 1. At most 63 characters in length 2. It must consist of lower
    case alphanumeric characters or `-` 3. It must start and end with an
    alphanumeric character Which can be expressed as the regex:
    `[a-z0-9]([-a-z0-9]*[a-z0-9])?`, with a maximum length of 63 characters.
  platformLabels: Output only. The labels of the cluster, coming from the
    platform api For example, a GKE cluster object labels are replicated
    here. This field is used by multi-cluster features as the source of
    labels and they ignore the membership labels (the `labels` field)
  state: Output only. State of the Membership resource.
  uniqueId: Output only. Google-generated UUID for this resource. This is
    unique across all Membership resources. If a Membership resource is
    deleted and another resource with the same name is created, it gets a
    different unique_id.
  updateTime: Output only. When the Membership was last updated.
c                   $    \ rS rSrSrSrSrSrSrg)%Membership.ClusterTierValueValuesEnumi5  zOutput only. The tier of the cluster.

Values:
  CLUSTER_TIER_UNSPECIFIED: The ClusterTier is not set.
  STANDARD: The ClusterTier is standard.
  ENTERPRISE: The ClusterTier is enterprise.
r   r   r(   r   N)	r   r   r   r   r   CLUSTER_TIER_UNSPECIFIEDSTANDARD
ENTERPRISEr   r   r   r   ClusterTierValueValuesEnumr9  5  s      !HJr   r=  c                   $    \ rS rSrSrSrSrSrSrg),Membership.InfrastructureTypeValueValuesEnumiA  a  Optional. The infrastructure type this Membership is running on.

Values:
  INFRASTRUCTURE_TYPE_UNSPECIFIED: No type was specified. Some Hub
    functionality may require a type be specified, and will not support
    Memberships with this value.
  ON_PREM: Private infrastructure that is owned or operated by customer.
    This includes GKE distributions such as GKE-OnPrem and GKE-
    OnBareMetal.
  MULTI_CLOUD: Public cloud infrastructure.
r   r   r(   r   N)	r   r   r   r   r   INFRASTRUCTURE_TYPE_UNSPECIFIEDON_PREMMULTI_CLOUDr   r   r   r   !InfrastructureTypeValueValuesEnumr?  A  s    
 '(#GKr   rC  c                        \ rS rSrSrSrSrSrg)(Membership.MembershipTypeValueValuesEnumiQ  zOutput only. The type of the membership.

Values:
  MEMBERSHIP_TYPE_UNSPECIFIED: The MembershipType is not set.
  LIGHTWEIGHT: The membership supports only lightweight compatible
    features.
r   r   r   N)r   r   r   r   r   MEMBERSHIP_TYPE_UNSPECIFIEDLIGHTWEIGHTr   r   r   r   MembershipTypeValueValuesEnumrE  Q  s     #$Kr   rH  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	)
Membership.LabelsValuei\  aX  Optional. Labels for this membership. These labels are not leveraged
by multi-cluster features, instead, we prefer cluster labels, which can be
set on GKE cluster or other cluster types.

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))Membership.LabelsValue.AdditionalPropertyii  r  r   r(   r   Nr  r   r   r   r   rL  i  r  r   r   r   Tr&   r   Nr   r   r   r   r  rJ  \  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	)
Membership.PlatformLabelsValueiv  a  Output only. The labels of the cluster, coming from the platform api
For example, a GKE cluster object labels are replicated here. This field
is used by multi-cluster features as the source of labels and they ignore
the membership labels (the `labels` field)

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

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

Fields:
  key: Name of the additional property.
  value: A string attribute.
r   r(   r   Nr  r   r   r   r   rP    r  r   r   r   Tr&   r   Nr   r   r   r   PlatformLabelsValuerN  v  s2    	'Y.. 	' %112FTXYr   rQ  r=   r   r(   r0   r?   r@   MembershipEndpointrA   r   r  r
  r  r  MonitoringConfigr  r  r  MembershipStater  r
      r   N)$r   r   r   r   r   r   r6   r=  rC  rH  r   r   r   r  rQ  r   	authorityr:   clusterTierr    r  r  r  endpoint
externalIdinfrastructureTyper  lastConnectionTimemembershipTypemonitoringConfigr   platformLabelsr   uniqueIdr   r   r   r   r   r  r    s   ?B
9>> 
)..  	inn 	 !!"89ZI%% Z :Z2 !!"89ZI-- Z :Z6 $$[!4)##$@!D+$$Q'*$$Q'*%%a(+##$8!<($$Q'* **+NPQR!!-3& ,,R0&&'FK.++,>C			r	"$))*?D.

 
 !2B
7%""2&($$R(*r   r  c                      \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " S5      r\R                  " S5      r\R                  " SS5      r\R                  " S	5      r\R                  " S
5      r\R                  " SS5      r\R                  " S5      r\R                  " S5      rSrg)r  i  a  MembershipBinding is a subresource of a Membership, representing what
Fleet Scopes (or other, future Fleet resources) a Membership is bound to.

Messages:
  LabelsValue: Optional. Labels for this MembershipBinding.

Fields:
  createTime: Output only. When the membership binding was created.
  deleteTime: Output only. When the membership binding was deleted.
  labels: Optional. Labels for this MembershipBinding.
  name: The resource name for the membershipbinding itself `projects/{projec
    t}/locations/{location}/memberships/{membership}/bindings/{membershipbin
    ding}`
  scope: A Scope resource name in the format
    `projects/*/locations/*/scopes/*`.
  state: Output only. State of the membership binding resource.
  uid: Output only. Google-generated UUID for this resource. This is unique
    across all membershipbinding resources. If a membershipbinding resource
    is deleted and another resource with the same name is created, it gets a
    different uid.
  updateTime: Output only. When the membership binding was last updated.
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	)
MembershipBinding.LabelsValuei  zOptional. Labels for this MembershipBinding.

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)0MembershipBinding.LabelsValue.AdditionalPropertyi  r  r   r(   r   Nr  r   r   r   r   rd    r  r   r   r   Tr&   r   Nr   r   r   r   r  rb    r  r   r  r   r(   r0   r?   r@   MembershipBindingLifecycleStaterA   r   r  r   N)r   r   r   r   r   r   r   r   r   r  r    r  r  r   r  r   r  r   r  r   r   r   r   r   r  r    s    . !!"89ZI%% Z :Z. $$Q'*$$Q'*!!-3&			q	!$



"%

 
 !BA
F%a #$$Q'*r   r  c                   h    \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	Sr
g)re  i  a  MembershipBindingLifecycleState describes the state of a Binding
resource.

Enums:
  CodeValueValuesEnum: Output only. The current state of the
    MembershipBinding resource.

Fields:
  code: Output only. The current state of the MembershipBinding resource.
c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
3MembershipBindingLifecycleState.CodeValueValuesEnumi  a7  Output only. The current state of the MembershipBinding resource.

Values:
  CODE_UNSPECIFIED: The code is not set.
  CREATING: The membershipbinding is being created.
  READY: The membershipbinding active.
  DELETING: The membershipbinding is being deleted.
  UPDATING: The membershipbinding is being updated.
r   r   r(   r0   r?   r   Nr  r   r   r   r   rh    r  r   r   r   r   Nr  r   r   r   re  re    ,    	INN   
		2A	6$r   re  c                   F   \ 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S5      r\R                  " SS5      r\R                  " SS5      rSrg)rR  i  a  MembershipEndpoint contains information needed to contact a Kubernetes
API, endpoint and any additional Kubernetes metadata.

Fields:
  applianceCluster: Optional. Specific information for a GDC Edge Appliance
    cluster.
  edgeCluster: Optional. Specific information for a Google Edge cluster.
  gkeCluster: Optional. Specific information for a GKE-on-GCP cluster.
  googleManaged: Output only. Whether the lifecycle of this membership is
    managed by a google cluster platform service.
  kubernetesMetadata: Output only. Useful Kubernetes-specific metadata.
  kubernetesResource: Optional. The in-cluster Kubernetes Resources that
    should be applied for a correctly registered cluster, in the steady
    state. These resources: * Ensure that the cluster is exclusively
    registered to one and only one Hub Membership. * Propagate Workload Pool
    Information available in the Membership Authority field. * Ensure proper
    initial configuration of default Hub Features.
  multiCloudCluster: Optional. Specific information for a GKE Multi-Cloud
    cluster.
  onPremCluster: Optional. Specific information for a GKE On-Prem cluster.
    An onprem user-cluster who has no resourceLink is not allowed to use
    this field, it should have a nil "type" instead.
r   r   r  r(   rE  r0   r?   r  r@   r  rA   MultiCloudClusterr   OnPremClusterr  r   N)r   r   r   r   r   r   r   applianceClusteredgeCluster
gkeClusterr8   googleManagedkubernetesMetadatakubernetesResourcemultiCloudClusteronPremClusterr   r   r   r   rR  rR    s    0 ++,>B&&}a8+%%lA6*((+- --.BAF --.BAF,,-@!D((!<-r   rR  c                      \ rS rSrSr\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r	\R                  " S	S
5      r
\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      rSrg)r  i!  ax  MembershipFeatureSpec contains configuration information for a single
Membership.

Fields:
  cloudbuild: Cloud Build-specific spec
  configDeliveryArgoCd: ConfigDeliveryArgoCD specific spec.
  configmanagement: Config Management-specific spec.
  fleetobservability: Fleet observability membership spec
  helloworld: Hello World-specific spec.
  identityservice: Identity Service-specific spec.
  mesh: Anthos Service Mesh-specific spec
  namespaceactuation: FNS Actuation membership spec
  origin: Whether this per-Membership spec was inherited from a fleet-level
    default. This field can be updated by users by either overriding a
    Membership config (updated to USER implicitly) or setting to FLEET
    explicitly.
  policycontroller: Policy Controller spec.
  rbacrolebindingactuation: RBAC Role Binding Actuation membership spec
  workloadcertificate: Workload Certificate spec.
r}   r   ru  r(   r,  r0   r/  r?   r-  r@   r.  rA   r/  r    NamespaceActuationMembershipSpecr  Originr
  r0  r  &RBACRoleBindingActuationMembershipSpecr  r  r  r   N)r   r   r   r   r   r   r   
cloudbuildconfigDeliveryArgoCdr1  r  r  r2  r  r  originr3  r  r  r   r   r   r   r  r  !  s    * %%&@!D*"//0TVWX++,LaP --.PRST%%&@!D***+JAN/			 ;Q	?$ --.PRST!!(A.&++,LbQ&334\^`a!../?Dr   r  c                   ,   \ rS rSrSr\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r	\R                  " S	S
5      r
\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      rSrg )!r  iE  aS  MembershipFeatureState contains Feature status information for a single
Membership.

Fields:
  appdevexperience: Appdevexperience specific state.
  clusterupgrade: ClusterUpgrade state.
  configDeliveryArgoCd: ConfigDeliveryArgoCD specific state.
  configmanagement: Config Management-specific state.
  fleetobservability: Fleet observability membership state.
  helloworld: Hello World-specific state.
  identityservice: Identity Service-specific state.
  metering: Metering-specific state.
  namespaceactuation: FNS Actuation membership state
  policycontroller: Policycontroller-specific state.
  rbacrolebindingactuation: RBAC Role Binding Actuation membership state
  servicemesh: Service Mesh-specific state.
  state: The high-level state of this Feature for a single membership.
  workloadidentity: Workload Identity membership specific state.
r   r   r   r(   r  r0   r<  r?   r2  r@   rz  rA   r  r   MeteringMembershipStater  !NamespaceActuationMembershipStater
  PolicyControllerMembershipStater  'RBACRoleBindingActuationMembershipStater  ServiceMeshMembershipStater  r'  r  WorkloadIdentityMembershipStater  r   N)r   r   r   r   r   r   r   r  r  rz  r1  r  r  r2  meteringr  r3  r  r)  r   r  r   r   r   r   r  r  E  s   ( ++,JAN))*I1M."//0UWXY++,MqQ --.QSTU%%&A1E***+KQO/##$=qA( --.QSTU++,MrR&334]_ab&&'CRH+

 
 
4%++,MrR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  ij  a  **Workload Certificate**: 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)3MembershipSpec.CertificateManagementValueValuesEnumiv  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[   r9  r   r   r   r   $CertificateManagementValueValuesEnumr  v  s     *+&HGr   r  r   r   N)r   r   r   r   r   r   r6   r  r:   certificateManagementr   r   r   r   r  r  j  s.    	Y^^  $--.TVWXr   r  c                   h    \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	Sr
g)rT  i  zMembershipState describes the state of a Membership resource.

Enums:
  CodeValueValuesEnum: Output only. The current state of the Membership
    resource.

Fields:
  code: Output only. The current state of the Membership 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
)#MembershipState.CodeValueValuesEnumi  ab  Output only. The current state of the Membership resource.

Values:
  CODE_UNSPECIFIED: The code is not set.
  CREATING: The cluster is being registered.
  READY: The cluster is registered.
  DELETING: The cluster is being unregistered.
  UPDATING: The Membership is being updated.
  SERVICE_UPDATING: The Membership is being updated by the Hub Service.
r   r   r(   r0   r?   r@   r   N)r   r   r   r   r   r   r  rn  r  r  r  r   r   r   r   r   r    s)    	 HEHHr   r   r   r   Nr  r   r   r   rT  rT    s,    INN $ 
		2A	6$r   rT  c                       \ rS rSrSr\R                  " S5      r\R                  " S\R                  R                  S9rSrg)r}  i  a2  **Metering**: Per-Membership 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   r}  r}    s9     "--a0+4+?+?9K\K\KbKb+c(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	)
rS  i  aG  MonitoringConfig informs Fleet-based applications/services/UIs how the
metrics for the underlying cluster is reported to cloud monitoring services.
It can be set from empty to non-empty, but can't be mutated directly to
prevent accidentally breaking the constinousty of metrics.

Fields:
  cluster: Optional. Cluster name used to report metrics. For Anthos on
    VMWare/Baremetal/MultiCloud clusters, it would be in format
    {cluster_type}/{cluster_name}, e.g., "awsClusters/cluster_1".
  clusterHash: Optional. For GKE and Multicloud clusters, this is the UUID
    of the cluster resource. For VMWare and Baremetal clusters, this is the
    kube-system UID.
  kubernetesMetricsPrefix: Optional. Kubernetes system metrics, if
    available, are written to this prefix. This defaults to kubernetes.io
    for GKE, and kubernetes.io/anthos for Anthos eventually. Noted: Anthos
    MultiCloud will have kubernetes.io prefix today but will migration to be
    under kubernetes.io/anthos.
  location: Optional. Location used to report Metrics
  projectId: Optional. Project used to report Metrics
r   r(   r0   r?   r@   r   N)r   r   r   r   r   r   r    r  clusterHashkubernetesMetricsPrefixr  	projectIdr   r   r   r   rS  rS    sZ    * !!!$'%%a(+%11!4""1%(##A&)r   rS  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      r	Sr
g)rk  i  a  MultiCloudCluster contains information specific to GKE Multi-Cloud
clusters.

Fields:
  clusterMissing: Output only. If cluster_missing is set then it denotes
    that API(gkemulticloud.googleapis.com) resource for this GKE Multi-Cloud
    cluster no longer exists.
  resourceLink: Immutable. Self-link of the Google Cloud resource for the
    GKE Multi-Cloud cluster. For example:
    //gkemulticloud.googleapis.com/projects/my-project/locations/us-
    west1-a/awsClusters/my-cluster
    //gkemulticloud.googleapis.com/projects/my-project/locations/us-
    west1-a/azureClusters/my-cluster
    //gkemulticloud.googleapis.com/projects/my-project/locations/us-
    west1-a/attachedClusters/my-cluster
r   r(   r   NrF  r   r   r   rk  rk    s)    " ))!,.&&q),r   rk  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  **Multi-cluster Ingress**: The configuration 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 Membership name which hosts the
    MultiClusterIngress CRD. Example: `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.BillingValueValuesEnumi  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    s     MNr   r  r   r(   r   N)r   r   r   r   r   r   r6   r  r:   billingr    configMembershipr   r   r   r   r  r    s=    y~~   8!<'**1-r   r  c                   .   \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " S5       " S S\R                  5      5       r
\R                  " S5      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S5      r\R(                  " S5      r\R                  " S5      r\R                  " S5      rSrg)r  i  aE  Namespace represents a namespace across the Fleet

Messages:
  LabelsValue: Optional. Labels for this Namespace.
  NamespaceLabelsValue: Optional. Namespace-level cluster namespace labels.
    These labels are applied to the related namespace of the member clusters
    bound to the parent Scope. Scope-level labels (`namespace_labels` in the
    Fleet Scope resource) take precedence over Namespace-level labels if
    they share a key. Keys and values must be Kubernetes-conformant.

Fields:
  createTime: Output only. When the namespace was created.
  deleteTime: Output only. When the namespace was deleted.
  labels: Optional. Labels for this Namespace.
  name: The resource name for the namespace
    `projects/{project}/locations/{location}/namespaces/{namespace}`
  namespaceLabels: Optional. Namespace-level cluster namespace labels. These
    labels are applied to the related namespace of the member clusters bound
    to the parent Scope. Scope-level labels (`namespace_labels` in the Fleet
    Scope resource) take precedence over Namespace-level labels if they
    share a key. Keys and values must be Kubernetes-conformant.
  scope: Required. Scope associated with the namespace
  state: Output only. State of the namespace resource.
  tenancyProject: Tenancy Project associated with the namespace
  uid: Output only. Google-generated UUID for this resource. This is unique
    across all namespace resources. If a namespace resource is deleted and
    another resource with the same name is created, it gets a different uid.
  updateTime: Output only. When the namespace was last updated.
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	)
Namespace.LabelsValuei'  zOptional. Labels for this Namespace.

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)(Namespace.LabelsValue.AdditionalPropertyi2  r  r   r(   r   Nr  r   r   r   r   r  2  r  r   r   r   Tr&   r   Nr   r   r   r   r  r  '  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	)
Namespace.NamespaceLabelsValuei?  a  Optional. Namespace-level cluster namespace labels. These labels are
applied to the related namespace of the member clusters bound to the
parent Scope. Scope-level labels (`namespace_labels` in the Fleet Scope
resource) take precedence over Namespace-level labels if they share a key.
Keys and values must be Kubernetes-conformant.

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

Fields:
  additionalProperties: Additional properties of type NamespaceLabelsValue
c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)1Namespace.NamespaceLabelsValue.AdditionalPropertyiO  An additional property for a NamespaceLabelsValue object.

Fields:
  key: Name of the additional property.
  value: A string attribute.
r   r(   r   Nr  r   r   r   r   r  O  r  r   r   r   Tr&   r   Nr   r   r   r   NamespaceLabelsValuer  ?  2    	'Y.. 	' %112FTXYr   r  r   r(   r0   r?   r@   rA   NamespaceLifecycleStater   r  r
  r  r   N)r   r   r   r   r   r   r   r   r   r  r  r    r  r  r   r  r   namespaceLabelsr  r   r   tenancyProjectr  r   r   r   r   r   r  r    s   < !!"89ZI%% Z :Z. !!"89ZY.. Z :Z8 $$Q'*$$Q'*!!-3&			q	!$**+A1E/



"%

 
 !:A
>%))!,.a #$$R(*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	  ih  a  An empty spec for actuation feature. This is required since Feature
proto requires a spec.

Enums:
  ActuationModeValueValuesEnum: actuation_mode controls the behavior of the
    controller

Fields:
  actuationMode: actuation_mode controls the behavior of the controller
c                   $    \ rS rSrSrSrSrSrSrg):NamespaceActuationFeatureSpec.ActuationModeValueValuesEnumit  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  t  s     "#23/12.r   r  r   r   N)r   r   r   r   r   r   r6   r  r:   actuationModer   r   r   r   r	  r	  h  s,    	3Y^^ 3& %%&DaH-r   r	  c                       \ rS rSrSrSrg)r$  i  z!NamespaceActuation Feature State.r   Nr   r   r   r   r$  r$    s    *r   r$  c                       \ rS rSrSrSrg)rv  i  zW**Namespace Actuation**: The membership-specific input for
NamespaceActuation feature.
r   Nr   r   r   r   rv  rv    r0  r   rv  c                       \ rS rSrSrSrg)r~  i  z_**Namespace Actuation**: An empty state left as an example membership-
specific Feature state.
r   Nr   r   r   r   r~  r~    r0  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  zNamespaceLifecycleState describes the state of a Namespace resource.

Enums:
  CodeValueValuesEnum: Output only. The current state of the Namespace
    resource.

Fields:
  code: Output only. The current state of the Namespace resource.
c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
+NamespaceLifecycleState.CodeValueValuesEnumi  a  Output only. The current state of the Namespace resource.

Values:
  CODE_UNSPECIFIED: The code is not set.
  CREATING: The namespace is being created.
  READY: The namespace active.
  DELETING: The namespace is being deleted.
  UPDATING: The namespace is being updated.
r   r   r(   r0   r?   r   Nr  r   r   r   r   r    r  r   r   r   r   Nr  r   r   r   r  r    s,    INN   
		2A	6$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5      rS	rg
)rl  i  a  OnPremCluster contains information specific to GKE On-Prem clusters.

Enums:
  ClusterTypeValueValuesEnum: Immutable. The on prem cluster's type.

Fields:
  adminCluster: Immutable. Whether the cluster is an admin cluster.
  clusterMissing: Output only. If cluster_missing is set then it denotes
    that API(gkeonprem.googleapis.com) resource for this GKE On-Prem cluster
    no longer exists.
  clusterType: Immutable. The on prem cluster's type.
  resourceLink: Immutable. Self-link of the Google Cloud resource for the
    GKE On-Prem cluster. For example:
    //gkeonprem.googleapis.com/projects/my-project/locations/us-
    west1-a/vmwareClusters/my-cluster
    //gkeonprem.googleapis.com/projects/my-project/locations/us-
    west1-a/bareMetalClusters/my-cluster
c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
(OnPremCluster.ClusterTypeValueValuesEnumi  a9  Immutable. The on prem cluster's type.

Values:
  CLUSTERTYPE_UNSPECIFIED: The ClusterType is not set.
  BOOTSTRAP: The ClusterType is bootstrap cluster.
  HYBRID: The ClusterType is baremetal hybrid cluster.
  STANDALONE: The ClusterType is baremetal standalone cluster.
  USER: The ClusterType is user cluster.
r   r   r(   r0   r?   r   N)r   r   r   r   r   CLUSTERTYPE_UNSPECIFIED	BOOTSTRAPHYBRID
STANDALONEUSERr   r   r   r   ClusterTypeValueValuesEnumr    s#      IFJDr   r  r   r(   r0   r?   r   N)r   r   r   r   r   r   r6   r  r8   adminClusterrG  r:   clusterTyper    r!   r   r   r   r   rl  rl    s\    &9>>   ''*,))!,.##$@!D+&&q),r   rl  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  i  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  r)  r   rP  r(   r   Nr   r   r   r   r   r    r  r   r   r   Tr&   r   Nr   r   r   r   r*  r    s4    	AY.. 	A %112FTXYr   r*  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
Operation.ResponseValuei*  a  The normal, successful response of the operation. If the original
method returns no data on success, such as `Delete`, the response is
`google.protobuf.Empty`. If the original method is standard
`Get`/`Create`/`Update`, the response should be the resource. For other
methods, the response should have the type `XxxResponse`, where `Xxx` is
the original method name. For example, if the original method name is
`TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`.

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

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

Fields:
  key: Name of the additional property.
  value: A extra_types.JsonValue attribute.
r   rP  r(   r   Nr   r   r   r   r   r  <  r  r   r   r   Tr&   r   Nr   r   r   r   ResponseValuer  *  s4     	AY.. 	A %112FTXYr   r  r   rI  r(   r0   r?   r@   r   N)r   r   r   r   r   r   r   r   r   r*  r  r8   doner   errorr,  r    r   responser   r   r   r   r  r    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)OperationMetadataiP  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 google.longrunning.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(   r0   r?   r@   rA   r   r   N)r   r   r   r   r   r   r    
apiVersionr8   cancelRequestedr  endTimestatusDetailtargetverbr   r   r   r   r  r  P  sy      $$Q'***1-/$$Q'*!!!$'&&q),  #&			q	!$r   r  c                   h    \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	Sr
g)rw  ij  zOrigin defines where this MembershipFeatureSpec originated from.

Enums:
  TypeValueValuesEnum: Type specifies which type of origin is set.

Fields:
  type: Type specifies which type of origin is set.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	Origin.TypeValueValuesEnumit  a}  Type specifies which type of origin is set.

Values:
  TYPE_UNSPECIFIED: Type is unknown or not set.
  FLEET: Per-Membership spec was inherited from the fleet-level default.
  FLEET_OUT_OF_SYNC: Per-Membership spec was inherited from the fleet-
    level default but is now out of sync with the current default.
  USER: Per-Membership spec was inherited from a user specification.
r   r   r(   r0   r   N)
r   r   r   r   r   r   FLEETFLEET_OUT_OF_SYNCr  r   r   r   r   r   r  t  s     EDr   r   r   r   N)r   r   r   r   r   r   r6   r   r:   r   r   r   r   r   rw  rw  j  s,    INN  
		2A	6$r   rw  c                       \ rS rSrSrSrg)r  i  z&Request message for pausing a rollout.r   Nr   r   r   r   r  r    s    /r   r  c                       \ rS rSrSr\R                  " SSSS9r\R                  " SSSS9r\R                  " S	5      r
\R                  " S
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&   rb   r(   r0   Ruler?   r@   r   r   N)r   r   r   r   r   r   r   auditConfigsbindingsrD   r  rulesr   r   r   r   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      rSrg)r^   i  zBinauthz policy that applies to this cluster.

Fields:
  name: The relative resource name of the binauthz platform policy to audit.
    GKE platform policies have the following format:
    `projects/{project_number}/platforms/gke/policies/{policy_id}`.
r   r   NrC  r   r   r   r^   r^     s     
		q	!$r   r^   c                   :    \ rS rSrSr\R                  " SSS9rSrg)!PolicyControllerBundleInstallSpeci  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    s     !,,Q>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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(   r0   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.DeploymentConfigsValuei5  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.AdditionalPropertyiC  zAn additional property for a DeploymentConfigsValue object.

Fields:
  key: Name of the additional property.
  value: A PolicyControllerPolicyControllerDeploymentConfig attribute.
r   0PolicyControllerPolicyControllerDeploymentConfigr(   r   Nr   r   r   r   r   r  C  s-    
 !!!$c$$%WYZ[er   r   r   Tr&   r   Nr   r   r   r   DeploymentConfigsValuer  5  s4    
	\Y.. 	\ %112FTXYr   r  r   r(   r0   r?   Tr&   r@   rA    PolicyControllerMonitoringConfigr   r  !PolicyControllerPolicyContentSpecr
  r  r   N)r   r   r   r   r   r   r6   r  r   r   r   r  r   rN  constraintViolationLimitr   deploymentConfigsr    rO  r:   installSpecr8   rP  rQ  rR  policyContentrS  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-/(()LaP-%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)r0  i\  z**Policy Controller**: Configuration for a single cluster. Intended to
parallel the PolicyController CR.

Fields:
  policyControllerHubConfig: Policy Controller configuration for the
    cluster.
  version: Version of Policy Controller installed.
r  r   r(   r   N)r   r   r   r   r   r   r   policyControllerHubConfigr    r   r   r   r   r   r0  r0  \  s.     (445PRST!!!$'r   r0  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  ij  ak  **Policy Controller**: State for a single cluster.

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

Messages:
  ComponentStatesValue: Currently these include (also serving as map keys):
    1. "admission" 2. "audit" 3. "mutation"

Fields:
  componentStates: 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)4PolicyControllerMembershipState.StateValueValuesEnumi~  aF
  The overall Policy Controller lifecycle state observed by the Hub
Feature controller.

Values:
  LIFECYCLE_STATE_UNSPECIFIED: The lifecycle state is unspecified.
  NOT_INSTALLED: The 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 PCH.
  INSTALLING: The PCH possesses a Membership, however the PC 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: The PC is fully installed on the cluster and in an operational
    mode. In this state PCH 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
    PCH expects.
  UPDATING: The 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 PCH 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: The PC may have resources on the cluster, but the PCH
    wishes to remove the Membership. The Membership still exists.
  CLUSTER_ERROR: The PC is not operational, and the PCH 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 PCH 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
    PCH 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 PCH
    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(   r0   r?   r@   rA   r   r  r
  r   Nr   r   r   r   r   LIFECYCLE_STATE_UNSPECIFIEDr  r  r  r  DECOMMISSIONINGCLUSTER_ERROR	HUB_ERROR	SUSPENDEDDETACHEDr   r   r   r   r   r  ~  s=    *V #$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	)
4PolicyControllerMembershipState.ComponentStatesValuei  a  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)GPolicyControllerMembershipState.ComponentStatesValue.AdditionalPropertyi  zAn additional property for a ComponentStatesValue object.

Fields:
  key: Name of the additional property.
  value: A PolicyControllerOnClusterState attribute.
r   PolicyControllerOnClusterStater(   r   Nr   r   r   r   r   r    ,    
 !!!$c$$%EqIer   r   r   Tr&   r   Nr   r   r   r   ComponentStatesValuer    4    		JY.. 	J %112FTXYr   r  r   "PolicyControllerPolicyContentStater(   r0   r   N)r   r   r   r   r   r   r6   r   r   r   r   r  r   componentStatespolicyContentStater:   r   r   r   r   r   r  r  j  s    &5Y^^ 5n !!"89ZY.. Z :Z2 **+A1E/ --.RTUV


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  i  a  MonitoringConfig 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)APolicyControllerMonitoringConfig.BackendsValueListEntryValuesEnumi  rb  r   r   r(   r   Nrc  r   r   r   rg  r    rh  r   rg  r   Tr&   r   Nri  r   r   r   r  r    rk  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)	r  i  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)3PolicyControllerOnClusterState.StateValueValuesEnumi  a
  The lifecycle state of this component.

Values:
  LIFECYCLE_STATE_UNSPECIFIED: The lifecycle state is unspecified.
  NOT_INSTALLED: The 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 PCH.
  INSTALLING: The PCH possesses a Membership, however the PC 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: The PC is fully installed on the cluster and in an operational
    mode. In this state PCH 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
    PCH expects.
  UPDATING: The 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 PCH 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: The PC may have resources on the cluster, but the PCH
    wishes to remove the Membership. The Membership still exists.
  CLUSTER_ERROR: The PC is not operational, and the PCH 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 PCH 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
    PCH 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 PCH
    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(   r0   r?   r@   rA   r   r  r
  r   Nr  r   r   r   r   r    s=    )T #$MJFHOMIIHr   r   r   r(   r   N)r   r   r   r   r   r   r6   r   r    rS  r:   r   r   r   r   r   r  r    s=    	4Y^^ 4l !!!$'


4a
8%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
)r  i7  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	)
.PolicyControllerPolicyContentSpec.BundlesValueiG  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)APolicyControllerPolicyContentSpec.BundlesValue.AdditionalPropertyiT  zAn additional property for a BundlesValue object.

Fields:
  key: Name of the additional property.
  value: A PolicyControllerBundleInstallSpec attribute.
r   r  r(   r   Nr   r   r   r   r   r$  T  s,    
 !!!$c$$%H!Ler   r   r   Tr&   r   Nr   r   r   r   BundlesValuer"  G  s4    		MY.. 	M %112FTXYr   r%  r   %PolicyControllerTemplateLibraryConfigr(   r   N)r   r   r   r   r   r   r   r   r   r%  r   bundlestemplateLibraryr   r   r   r   r  r  7  s_     !!"89ZY&& Z :Z2 "">15'**+RTUV/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)r  ie  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	)
4PolicyControllerPolicyContentState.BundleStatesValueiv  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)GPolicyControllerPolicyContentState.BundleStatesValue.AdditionalPropertyi  zAn additional property for a BundleStatesValue object.

Fields:
  key: Name of the additional property.
  value: A PolicyControllerOnClusterState attribute.
r   r  r(   r   Nr   r   r   r   r   r-    r  r   r   r   Tr&   r   Nr   r   r   r   BundleStatesValuer+  v  r  r   r.  r   r  r(   r0   r   N)r   r   r   r   r   r   r   r   r   r.  r   bundleStatesreferentialSyncConfigStatetemplateLibraryStater   r   r   r   r  r  e  sv      !!"89Z)++ Z :Z2 ''(;Q?,(556VXYZ"//0PRST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)r  i  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)KPolicyControllerPolicyControllerDeploymentConfig.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   PodAffinityValueValuesEnumr4    s     KMr   r8  $PolicyControllerResourceRequirementsr   r(   r0   PolicyControllerTolerationr?   Tr&   r@   r   N)r   r   r   r   r   r   r6   r8  r   containerResourcesr:   podAffinityr8   podAntiAffinitypodTolerationsr   replicaCountr   r   r   r   r  r    sw    9>>  !--.TVWX##$@!D+**1-/))*FTXY.''*,r   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)PolicyControllerResourceListi  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   rA  rA    s)     	a #  #&r   rA  c                   d    \ rS rSrSr\R                  " SS5      r\R                  " SS5      rSr	g)r9  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.
rA  r   r(   r   N)
r   r   r   r   r   r   r   limitsrequestsr   r   r   r   r9  r9    s/     !!"@!D&##$BAF(r   r9  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)APolicyControllerTemplateLibraryConfig.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_UNSPECIFIEDr  ALLr   r   r   r   InstallationValueValuesEnumrI    s      !M
Cr   rL  r   r   N)r   r   r   r   r   r   r6   rL  r:   installationr   r   r   r   r&  r&    s,    	INN  $$%BAF,r   r&  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S5      r	\R                  " S5      r
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(   r0   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       " S S\R                  5      5       r	\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                  " SS	5      r\R                  " S
5      r\R                  " SS5      r\R                  " SS5      r\R                  " S5      r\R                  " S5      r\R                  " S5      rSrg)r  i  a  RBACRoleBinding represents a rbacrolebinding across the Fleet

Messages:
  LabelsValue: Optional. Labels for this RBACRolebinding.

Fields:
  createTime: Output only. When the rbacrolebinding was created.
  deleteTime: Output only. When the rbacrolebinding was deleted.
  group: group is the group, as seen by the kubernetes cluster.
  labels: Optional. Labels for this RBACRolebinding.
  name: The resource name for the rbacrolebinding `projects/{project}/locati
    ons/{location}/scopes/{scope}/rbacrolebindings/{rbacrolebinding}` or `pr
    ojects/{project}/locations/{location}/memberships/{membership}/rbacroleb
    indings/{rbacrolebinding}`
  role: Required. Role to bind to the principal
  state: Output only. State of the rbacrolebinding resource.
  uid: Output only. Google-generated UUID for this resource. This is unique
    across all rbacrolebinding resources. If a rbacrolebinding resource is
    deleted and another resource with the same name is created, it gets a
    different uid.
  updateTime: Output only. When the rbacrolebinding was last updated.
  user: user is the name of the user as seen by the kubernetes cluster,
    example "alice" or "alice@domain.tld"
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	)
RBACRoleBinding.LabelsValuei  zOptional. Labels for this RBACRolebinding.

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).RBACRoleBinding.LabelsValue.AdditionalPropertyi$  r  r   r(   r   Nr  r   r   r   r   rU  $  r  r   r   r   Tr&   r   Nr   r   r   r   r  rS    r  r   r  r   r(   r0   r?   r@   RolerA   RBACRoleBindingLifecycleStater   r  r
  r  r   N)r   r   r   r   r   r   r   r   r   r  r    r  r  r  r   r  r   rh   r   r  r   r  r   r   r   r   r  r    s    2 !!"89ZI%% Z :Z. $$Q'*$$Q'*



"%!!-3&			q	!$				*$

 
 !@!
D%a #$$Q'*			r	"$r   r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)r  i=  a_  **RBAC RoleBinding Actuation**: The Hub-wide input for the
RBACRoleBindingActuation feature.

Fields:
  allowedCustomRoles: The list of allowed custom roles (ClusterRoles). If a
    ClusterRole is not part of this list, it cannot be used in a Scope
    RBACRoleBinding. If a ClusterRole in this list is in use, it cannot be
    removed from the list.
r   Tr&   r   N)	r   r   r   r   r   r   r    allowedCustomRolesr   r   r   r   r  r  =  s     !,,Q>r   r  c                       \ rS rSrSrSrg)r%  iK  z[**RBAC RoleBinding Actuation**: An empty state left as an example Hub-
wide Feature state.
r   Nr   r   r   r   r%  r%  K  r0  r   r%  c                       \ rS rSrSrSrg)rx  iR  zd**RBAC RoleBinding Actuation**: The membership-specific input for
RBACRoleBindingActuation feature.
r   Nr   r   r   r   rx  rx  R  r0  r   rx  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  iY  a  **RBAC RoleBinding Actuation**: A membership-specific Feature state for
the RBACRoleBindingActuation fleet feature.

Messages:
  RbacrolebindingStatesValue: Output only. The state of RBACRoleBindings
    using custom roles that exist on the cluster, keyed by RBACRoleBinding
    resource name with format: projects/{project}/locations/{location}/scope
    s/{scope}/rbacrolebindings/{rbacrolebinding}.

Fields:
  rbacrolebindingStates: Output only. The state of RBACRoleBindings using
    custom roles that exist on the cluster, keyed by RBACRoleBinding
    resource name with format: projects/{project}/locations/{location}/scope
    s/{scope}/rbacrolebindings/{rbacrolebinding}.
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	)
BRBACRoleBindingActuationMembershipState.RbacrolebindingStatesValueij  a  Output only. The state of RBACRoleBindings using custom roles that
exist on the cluster, keyed by RBACRoleBinding resource name with format:
projects/{project}/locations/{location}/scopes/{scope}/rbacrolebindings/{r
bacrolebinding}.

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

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

Fields:
  key: Name of the additional property.
  value: A RBACRoleBindingActuationRBACRoleBindingState attribute.
r   ,RBACRoleBindingActuationRBACRoleBindingStater(   r   Nr   r   r   r   r   r`  z  s-    
 !!!$c$$%SUVWer   r   r   Tr&   r   Nr   r   r   r   RbacrolebindingStatesValuer^  j  s4    	XY.. 	X %112FTXYr   rb  r   r   N)r   r   r   r   r   r   r   r   r   rb  r   rbacrolebindingStatesr   r   r   r   r  r  Y  sM      !!"89Z9#4#4 Z :Z8 $001MqQr   r  c                       \ rS rSrSr " S S\R                  5      r\R                  " S5      r	\R                  " SS5      r\R                  " S5      rSrg	)
ra  i  aV  RBACRoleBindingState is the status of an RBACRoleBinding which exists on
a membership.

Enums:
  StateValueValuesEnum: Output only. The state of the RBACRoleBinding.

Fields:
  description: The reason for the failure.
  state: Output only. The state of the RBACRoleBinding.
  updateTime: The time the RBACRoleBinding status was last updated.
c                   $    \ rS rSrSrSrSrSrSrg)ARBACRoleBindingActuationRBACRoleBindingState.StateValueValuesEnumi  ah  Output only. The state of the RBACRoleBinding.

Values:
  ROLE_BINDING_STATE_UNSPECIFIED: Unspecified state.
  OK: RBACRoleBinding is created properly on the cluster.
  CUSTOM_ROLE_MISSING_FROM_CLUSTER: The RBACRoleBinding was created on the
    cluster but the specified custom role does not exist on the cluster,
    hence the RBACRoleBinding has no effect.
r   r   r(   r   N)	r   r   r   r   r   ROLE_BINDING_STATE_UNSPECIFIEDr   CUSTOM_ROLE_MISSING_FROM_CLUSTERr   r   r   r   r   rf    s     &'"	
B'($r   r   r   r(   r0   r   N)r   r   r   r   r   r   r6   r   r    r  r:   r   r   r   r   r   r   ra  ra    sL    
)Y^^ ) %%a(+


4a
8%$$Q'*r   ra  c                   h    \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	Sr
g)rW  i  a  RBACRoleBindingLifecycleState describes the state of a RbacRoleBinding
resource.

Enums:
  CodeValueValuesEnum: Output only. The current state of the rbacrolebinding
    resource.

Fields:
  code: Output only. The current state of the rbacrolebinding resource.
c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
1RBACRoleBindingLifecycleState.CodeValueValuesEnumi  a-  Output only. The current state of the rbacrolebinding resource.

Values:
  CODE_UNSPECIFIED: The code is not set.
  CREATING: The rbacrolebinding is being created.
  READY: The rbacrolebinding active.
  DELETING: The rbacrolebinding is being deleted.
  UPDATING: The rbacrolebinding is being updated.
r   r   r(   r0   r?   r   Nr  r   r   r   r   rk    r  r   r   r   r   Nr  r   r   r   rW  rW    ri  r   rW  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  rL  c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)2Reference.DetailsValueListEntry.AdditionalPropertyi  rO  r   rP  r(   r   Nr   r   r   r   r   rp    r  r   r   r   Tr&   r   Nr   r   r   r   rQ  rn    rR  r   rQ  r   r(   Tr&   r0   r?   r@   rA   r   N)r   r   r   r   r   r   r   r   r   rQ  r    r  r   rS  r   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)r  i  a  ResourceManifest represents a single Kubernetes resource to be applied
to the cluster.

Fields:
  clusterScoped: Output only. Whether the resource provided in the manifest
    is `cluster_scoped`. If unset, the manifest is assumed to be namespace
    scoped. This field is used for REST mapping when applying the resource
    in a cluster.
  manifest: Output only. YAML manifest of the resource.
r   r(   r   N)r   r   r   r   r   r   r8   clusterScopedr    r  r   r   r   r   r  r    s)    	 ((+-""1%(r   r  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S5      r	\R                  " S5      rSrg)	r  i  a  ResourceOptions represent options for Kubernetes resource generation.

Fields:
  connectVersion: Optional. The Connect agent version to use for
    connect_resources. Defaults to the latest GKE Connect version. The
    version must be a currently supported version, obsolete versions will be
    rejected.
  k8sGitVersion: Optional. Git version of the Kubernetes cluster. This is
    only used to gate the Connect Agent migration to svc.id.goog on GDC-SO
    1.33.100 patch and above.
  k8sVersion: Optional. Major and minor version of the Kubernetes cluster.
    This is only used to determine which version to use for the
    CustomResourceDefinition resources, `apiextensions/v1beta1`
    or`apiextensions/v1`.
  v1beta1Crd: Optional. Use `apiextensions/v1beta1` instead of
    `apiextensions/v1` for CustomResourceDefinition resources. This option
    should be set for clusters with Kubernetes apiserver versions <1.16.
r   r(   r0   r?   r   N)r   r   r   r   r   r   r    connectVersionk8sGitVersion
k8sVersionr8   
v1beta1Crdr   r   r   r   r  r    sI    & ((+.''*-$$Q'*%%a(*r   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      r	Sr
g)r  i0  zRequest message for resuming a rollout.

Fields:
  scheduleOffset: Optional. The duration to offset the Rollout schedule by.
  validateOnly: Optional. If set, resume rollout will be executed in dry-run
    mode.
r   r(   r   N)r   r   r   r   r   r   r    scheduleOffsetr8   validateOnlyr   r   r   r   r  r  0  s)     ((+.''*,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)	rV  i=  a8  Role is the type for Kubernetes roles

Enums:
  PredefinedRoleValueValuesEnum: predefined_role is the Kubernetes default
    role to use

Fields:
  customRole: Optional. custom_role is the name of a custom
    KubernetesClusterRole to use.
  predefinedRole: predefined_role is the Kubernetes default role to use
c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
"Role.PredefinedRoleValueValuesEnumiJ  aA  predefined_role is the Kubernetes default role to use

Values:
  UNKNOWN: UNKNOWN
  ADMIN: ADMIN has EDIT and RBAC permissions
  EDIT: EDIT can edit all resources except RBAC
  VIEW: VIEW can only read resources
  ANTHOS_SUPPORT: ANTHOS_SUPPORT gives Google Support read-only access to
    a number of cluster resources.
r   r   r(   r0   r?   r   N)r   r   r   r   r   ri  ADMINEDITVIEWANTHOS_SUPPORTr   r   r   r   PredefinedRoleValueValuesEnumr  J  s"    	 GEDDNr   r  r   r(   r   N)r   r   r   r   r   r   r6   r  r    
customRoler:   predefinedRoler   r   r   r   rV  rV  =  s<    
inn " $$Q'*&&'FJ.r   rV  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       " S S	\R                  5      5       r\R                  " S5       " S
 S\R                  5      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\R                  " SSSS9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5      r\R"                  " S 5      r\R                  " S!S"5      r\R"                  " S#5      r \R                  " S$S%SS9r!\RD                  " SS&5      r#\R"                  " S'5      r$\R"                  " S(5      r%\R"                  " S)5      r&\R                  " S*S+5      r'S,r(g-).r
  i_  a  Rollout contains the Rollout metadata and configuration.

Enums:
  StateValueValuesEnum: Output only. State specifies various states of the
    Rollout.

Messages:
  AnnotationsValue: Optional. Annotations for this Rollout.
  LabelsValue: Optional. Labels for this Rollout.
  MembershipStatesValue: Output only. States of upgrading control plane or
    node pool targets of a single cluster (GKE Hub membership) that's part
    of this Rollout. The key is the membership name of the cluster. The
    value is the state of the cluster.

Fields:
  annotations: Optional. Annotations for this Rollout.
  clusterStatus: Output only. Metadata about the cluster status which are
    part of the Rollout. Provided by the server.
  completeTime: Output only. The timestamp at which the Rollout was
    completed.
  createTime: Output only. The timestamp at which the Rollout was created.
  deleteTime: Output only. The timestamp at the Rollout was deleted.
  displayName: Optional. Human readable display name of the Rollout.
  etag: Output only. etag of the Rollout Ex. abc1234
  excludedClusters: Optional. Output only. The excluded clusters from the
    rollout.
  feature: Optional. Feature config to use for Rollout.
  labels: Optional. Labels for this Rollout.
  lastPauseTime: Output only. The timestamp at which the Rollout was last
    paused.
  managedRolloutConfig: Optional. The configuration used for the Rollout.
  membershipStates: Output only. States of upgrading control plane or node
    pool targets of a single cluster (GKE Hub membership) that's part of
    this Rollout. The key is the membership name of the cluster. The value
    is the state of the cluster.
  name: Identifier. The full, unique resource name of this Rollout in the
    format of `projects/{project}/locations/global/rollouts/{rollout}`.
  rolloutSequence: Optional. Immutable. The full, unique resource name of
    the rollout sequence that initiatied this Rollout. In the format of `pro
    jects/{project}/locations/global/rolloutSequences/{rollout_sequence}`.
    Empty for user initiated rollouts.
  schedule: Output only. The schedule of the Rollout.
  scheduledStartTime: Optional. The timestamp at which the Rollout is
    scheduled to start. If not specified, the Rollout will start
    immediately.
  stages: Output only. The stages of the Rollout. Note: this is only
    populated for google-initiated rollouts.
  state: Output only. State specifies various states of the Rollout.
  stateReason: Output only. A human-readable description explaining the
    reason for the current state.
  uid: Output only. Google-generated UUID for this resource. This is unique
    across all Rollout resources. If a Rollout resource is deleted and
    another resource with the same name is created, it gets a different uid.
  updateTime: Output only. The timestamp at which the Rollout was last
    updated.
  versionUpgrade: Optional. Config for version upgrade of clusters. Note:
    Currently for GDCE clusters only.
c                   0    \ rS rSrSrSrSrSrSrSr	Sr
S	rg
)Rollout.StateValueValuesEnumi  aK  Output only. State specifies various states of the Rollout.

Values:
  STATE_UNSPECIFIED: Unspecified state.
  RUNNING: The Rollout is running.
  PAUSED: The Rollout is paused.
  CANCELLED: The Rollout is in a failure terminal state.
  COMPLETED: The Rollout is in a terminal state.
  SCHEDULED: The Rollout is scheduled to start.
r   r   r(   r0   r?   r@   r   N)r   r   r   r   r   r   r   r   	CANCELLED	COMPLETED	SCHEDULEDr   r   r   r   r   r    s(    	 GFIIIr   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	)
Rollout.AnnotationsValuei  zOptional. Annotations for this Rollout.

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

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

Fields:
  key: Name of the additional property.
  value: A string attribute.
r   r(   r   Nr  r   r   r   r   r    r  r   r   r   Tr&   r   Nr   r   r   r   AnnotationsValuer    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	)
Rollout.LabelsValuei  zOptional. Labels for this Rollout.

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)&Rollout.LabelsValue.AdditionalPropertyi  r  r   r(   r   Nr  r   r   r   r   r    r  r   r   r   Tr&   r   Nr   r   r   r   r  r    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	)
Rollout.MembershipStatesValuei  a  Output only. States of upgrading control plane or node pool targets of
a single cluster (GKE Hub membership) that's part of this Rollout. The key
is the membership name of the cluster. The value is the state of the
cluster.

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

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

Fields:
  key: Name of the additional property.
  value: A RolloutMembershipState attribute.
r   RolloutMembershipStater(   r   Nr   r   r   r   r   r    r  r   r   r   Tr&   r   Nr   r   r   r   r  r    s4    	BY.. 	B %112FTXYr   r  r   r   r(   Tr&   r0   r?   r@   rA   r   r  r  r  r
  r  r  r3  r  r  r  r  Scheduler
   rU  RolloutStage      r         VersionUpgrade   r   N))r   r   r   r   r   r   r6   r   r   r   r   r  r  r  r   annotationsclusterStatusr    completeTimer  r  r  r  excludedClustersrR  r  lastPauseTimemanagedRolloutConfigr  r   r  schedulescheduledStartTimestagesr:   r   stateReasonr  r   versionUpgrader   r   r   r   r
  r
  _  s@   9vY^^ $ !!"89Z** Z :Z0 !!"89ZI%% Z :Z. !!"89Zi// Z :Z8 &&'91=+((!dK-&&q),$$Q'*$$Q'*%%a(+			q	!$++,=q4P""?A6'!!-4&''+-"//0FK++,CRH			r	"$))"-/##J3( ,,R0!!."tD&


4b
9%%%b)+b!#$$R(*))*:B?.r   r
  c                       \ rS rSrSr\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " SSSS	9r\R                  " S
\R                  R                  S9rSrg)r  i  ao  Metadata about single cluster (GKE Hub membership) that's part of this
Rollout.

Fields:
  lastUpdateTime: Optional. Output only. The time this status and any
    related Rollout-specific details for the membership were updated.
  stageAssignment: Output only. The stage assignment of this cluster in this
    rollout.
  targets: Output only. The targets of the rollout - clusters or node pools
    that are being upgraded. All targets belongs to the same cluster,
    identified by the membership name (key of membership_states map).
  waveAssignment: Output only. The wave assignment of this cluster in this
    rollout.
r   r(   r   RolloutTargetr0   Tr&   r?   r   N)r   r   r   r   r   r   r    r   r   r   r   stageAssignmentr   targetsr   r   r   r   r   r  r    si     ((+.**1i6G6G6M6MN/""?AE'))!Y5F5F5L5LM.r   r  c                      \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                  " S	5      r\R                  " SS
5      r\R                  " S5      r\R                  " SSSS9r\R                  " S5      r\R                  " S5      rSrg)r  i*  a  RolloutSequence defines the desired order of upgrades.

Messages:
  LabelsValue: Optional. Labels for this Rollout Sequence.

Fields:
  createTime: Output only. The timestamp at which the Rollout Sequence was
    created.
  deleteTime: Output only. The timestamp at the Rollout Sequence was
    deleted.
  displayName: Optional. Human readable display name of the Rollout
    Sequence.
  etag: Output only. etag of the Rollout Sequence Ex. abc1234
  labels: Optional. Labels for this Rollout Sequence.
  name: Identifier. Name of the rollout sequence in the format of:
    projects/{PROJECT_ID}/locations/global/rolloutSequences/{NAME}
  stages: Required. Ordered list of stages that constitutes this Rollout.
  uid: Output only. Google-generated UUID for this resource. This is unique
    across all Rollout Sequence resources. If a Rollout Sequence resource is
    deleted and another resource with the same name is created, it gets a
    different uid.
  updateTime: Output only. The timestamp at which the Rollout Sequence was
    last updated.
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	)
RolloutSequence.LabelsValueiD  zOptional. Labels for this Rollout Sequence.

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).RolloutSequence.LabelsValue.AdditionalPropertyiO  r  r   r(   r   Nr  r   r   r   r   r  O  r  r   r   r   Tr&   r   Nr   r   r   r   r  r  D  r  r   r  r   r(   r0   r?   r@   rA   Stager   Tr&   r  r
  r   N)r   r   r   r   r   r   r   r   r   r  r    r  r  r  r  r   r  r   r  r  r   r   r   r   r   r  r  *  s    2 !!"89ZI%% Z :Z. $$Q'*$$Q'*%%a(+			q	!$!!-3&			q	!$!!'1t<&a #$$Q'*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\R                  R                  S9r\R                  " S	5      r\R                   " SS
5      rSrg)r  ig  a  Stage represents a single stage in the Rollout.

Enums:
  StateValueValuesEnum: Output only. The state of the wave.

Fields:
  endTime: Optional. Output only. The time at which the wave ended.
  soakDuration: Optional. Duration to soak after this wave before starting
    the next wave.
  stageNumber: Output only. The wave number to which this status applies.
  startTime: Optional. Output only. The time at which the wave started.
  state: Output only. The state of the wave.
c                   0    \ rS rSrSrSrSrSrSrSr	Sr
S	rg
)!RolloutStage.StateValueValuesEnumiv  a  Output only. The state of the wave.

Values:
  STATE_UNSPECIFIED: Default value.
  PENDING: The wave is pending.
  RUNNING: The wave is running.
  SOAKING: The wave is soaking.
  COMPLETED: The wave is completed.
  FORCED_SOAKING: The wave is force soaking.
r   r   r(   r0   r?   r@   r   N)r   r   r   r   r   r   r   r   r   r  r   r   r   r   r   r   r  v  s(    	 GGGINr   r   r   r(   r0   r   r?   r@   r   N)r   r   r   r   r   r   r6   r   r    r  r5  r   r   r   stageNumber	startTimer:   r   r   r   r   r   r  r  g  sz    Y^^ $ !!!$'&&q),&&q)2C2C2I2IJ+##A&)


4a
8%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5      r\R                  " S5      r\R                  " SS	5      rS
rg)r  i  a  Metadata about the status of targets (clusters or node pools) involved
in the Rollout.

Enums:
  StateValueValuesEnum: Output only. The high-level, machine-readable status
    of this Rollout for the target.

Fields:
  cluster: Optional. Output only. The resource link of the Cluster resource
    upgraded in this Rollout. It is formatted as:
    ///projects//locations//clusters/. I.e. for GKE clusters, it is
    formatted as: //container.googleapis.com/projects//locations//clusters/.
    For GDCE, it is formatted as:
    //edgecontainer.googleapis.com/projects//locations//clusters/.
  nodePool: Optional. Output only. The resource link of the NodePool
    resource upgraded in this Rollout. It is formatted as:
    ///projects//locations//clusters//nodePools/.
  operation: Optional. Output only. The operation resource name performing
    the mutation.
  reason: Optional. Output only. A human-readable description of the current
    status.
  state: Output only. The high-level, machine-readable status of this
    Rollout for the target.
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)"RolloutTarget.StateValueValuesEnumi  a  Output only. The high-level, machine-readable status of this Rollout
for the target.

Values:
  STATE_UNSPECIFIED: Unspecified state.
  PENDING: The Rollout is pending for the target.
  RUNNING: The Rollout is running for the target.
  FAILED: The Rollout failed for the target.
  SUCCEEDED: The Rollout succeeded for the target.
  PAUSED: The Rollout is paused for the target.
  REMOVED: The target was removed from the Rollout.
  INELIGIBLE: The target is ineligible for the Rollout.
r   r   r(   r0   r?   r@   rA   r   r   Nr   r   r   r   r   r    r   r   r   r   r(   r0   r?   r@   r   N)r   r   r   r   r   r   r6   r   r    r  nodePoolr   r   r:   r   r   r   r   r   r  r    sl    2Y^^ . !!!$'""1%(##A&)  #&


4a
8%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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(   r0   r?   r@   r   N)r   r   r   r   r   	NO_ACTIONALLOWALLOW_WITH_LOGDENYDENY_WITH_LOGLOGr   r   r   r   ActionValueValuesEnumr    s'     IENDM
Cr   r  r   rA  r(   Tr&   r0   r?   r.  r@   rA   r   r   N)r   r   r   r   r   r   r6   r  r:   actionr   r   r    r  in_	logConfignotInpermissionsr   r   r   r   r  r    s    .inn ( 6:&%%k1tD*%%a(+a$/#$$[!dC)


D
1%%%a$7+r   r  c                   <    \ rS rSrSr\R                  " SSSS9rSrg)	r  i  zzSchedule represents the schedule of the Rollout.

Fields:
  waves: Output only. The schedule of each wave in the Rollout.
WaveScheduler   Tr&   r   N)	r   r   r   r   r   r   r   wavesr   r   r   r   r  r    s     
 
 T
B%r   r  c                      \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " S5       " S S\R                  5      5       r
\R                  " S5      r\R                  " S	5      r\R                  " SS
5      r\R                  " S5      r\R                  " SS5      r\R                  " SS5      r\R                  " S5      r\R                  " S5      rSrg)r  i   a  Scope represents a Scope in a Fleet.

Messages:
  LabelsValue: Optional. Labels for this Scope.
  NamespaceLabelsValue: Optional. Scope-level cluster namespace labels. For
    the member clusters bound to the Scope, these labels are applied to each
    namespace under the Scope. Scope-level labels take precedence over
    Namespace-level labels (`namespace_labels` in the Fleet Namespace
    resource) if they share a key. Keys and values must be Kubernetes-
    conformant.

Fields:
  createTime: Output only. When the scope was created.
  deleteTime: Output only. When the scope was deleted.
  labels: Optional. Labels for this Scope.
  name: The resource name for the scope
    `projects/{project}/locations/{location}/scopes/{scope}`
  namespaceLabels: Optional. Scope-level cluster namespace labels. For the
    member clusters bound to the Scope, these labels are applied to each
    namespace under the Scope. Scope-level labels take precedence over
    Namespace-level labels (`namespace_labels` in the Fleet Namespace
    resource) if they share a key. Keys and values must be Kubernetes-
    conformant.
  state: Output only. State of the scope resource.
  uid: Output only. Google-generated UUID for this resource. This is unique
    across all scope resources. If a scope resource is deleted and another
    resource with the same name is created, it gets a different uid.
  updateTime: Output only. When the scope was last updated.
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	)
Scope.LabelsValuei%   zOptional. Labels for this Scope.

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)$Scope.LabelsValue.AdditionalPropertyi0   r  r   r(   r   Nr  r   r   r   r   r  0   r  r   r   r   Tr&   r   Nr   r   r   r   r  r  %   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	)
Scope.NamespaceLabelsValuei=   a  Optional. Scope-level cluster namespace labels. For the member
clusters bound to the Scope, these labels are applied to each namespace
under the Scope. Scope-level labels take precedence over Namespace-level
labels (`namespace_labels` in the Fleet Namespace resource) if they share
a key. Keys and values must be Kubernetes-conformant.

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

Fields:
  additionalProperties: Additional properties of type NamespaceLabelsValue
c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)-Scope.NamespaceLabelsValue.AdditionalPropertyiM   r  r   r(   r   Nr  r   r   r   r   r  M   r  r   r   r   Tr&   r   Nr   r   r   r   r  r  =   r  r   r  r   r(   r0   r?   r@   ScopeLifecycleStaterA   r   r  r   N)r   r   r   r   r   r   r   r   r   r  r  r    r  r  r   r  r   r  r   r  r   r   r   r   r   r  r     s    < !!"89ZI%% Z :Z. !!"89ZY.. Z :Z8 $$Q'*$$Q'*!!-3&			q	!$**+A1E/

 
 !6
:%a #$$Q'*r   r  c                   d    \ rS rSrSr\R                  " SS5      r\R                  " SS5      rSr	g)	r  id   zScopeFeatureSpec contains feature specs for a fleet scope.

Fields:
  clusterupgrade: Spec for the ClusterUpgrade feature at the scope level
  helloworld: Spec for the HelloWorld feature at the scope level
r   r   r|  r(   r   N)
r   r   r   r   r   r   r   r  r  r   r   r   r   r  r  d   s/     ))*CQG.%%&;Q?*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	S	r
g
)r  ip   a  ScopeFeatureState contains Scope-wide Feature status information.

Fields:
  clusterupgrade: State for the ClusterUpgrade feature at the scope level
  helloworld: State for the HelloWorld feature at the scope level
  state: Output only. The "running state" of the Feature in this Scope.
r   r   r~  r(   r'  r0   r   N)r   r   r   r   r   r   r   r  r  r   r   r   r   r   r  r  p   sA     ))*DaH.%%&<a@*

 
 
3%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~   zScopeLifecycleState describes the state of a Scope resource.

Enums:
  CodeValueValuesEnum: Output only. The current state of the scope resource.

Fields:
  code: Output only. The current state of the scope resource.
c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
'ScopeLifecycleState.CodeValueValuesEnumi   zOutput only. The current state of the scope resource.

Values:
  CODE_UNSPECIFIED: The code is not set.
  CREATING: The scope is being created.
  READY: The scope active.
  DELETING: The scope is being deleted.
  UPDATING: The scope is being updated.
r   r   r(   r0   r?   r   Nr  r   r   r   r   r     r  r   r   r   r   Nr  r   r   r   r  r  ~   r  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
)r  i   a  SecurityPostureConfig defines the flags needed to enable/disable
features for the Security Posture API.

Enums:
  ModeValueValuesEnum: Sets which mode to use for Security Posture features.
  VulnerabilityModeValueValuesEnum: Sets which mode to use for vulnerability
    scanning.

Fields:
  mode: Sets which mode to use for Security Posture features.
  vulnerabilityMode: Sets which mode to use for vulnerability scanning.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	)SecurityPostureConfig.ModeValueValuesEnumi   a@  Sets which mode to use for Security Posture features.

Values:
  MODE_UNSPECIFIED: Default value not specified.
  DISABLED: Disables Security Posture features on the cluster.
  BASIC: Applies Security Posture features on the cluster.
  ENTERPRISE: Applies the Security Posture off cluster Enterprise level
    features.
r   r   r(   r0   r   N)
r   r   r   r   r   r8  r[   BASICr<  r   r   r   r   r:  r     s     HEJr   r:  c                   (    \ rS rSrSrSrSrSrSrSr	g)	6SecurityPostureConfig.VulnerabilityModeValueValuesEnumi   a  Sets which mode to use for vulnerability scanning.

Values:
  VULNERABILITY_MODE_UNSPECIFIED: Default value not specified.
  VULNERABILITY_DISABLED: Disables vulnerability scanning on the cluster.
  VULNERABILITY_BASIC: Applies basic vulnerability scanning on the
    cluster.
  VULNERABILITY_ENTERPRISE: Applies the Security Posture's vulnerability
    on cluster Enterprise level features.
r   r   r(   r0   r   N)
r   r   r   r   r   VULNERABILITY_MODE_UNSPECIFIEDVULNERABILITY_DISABLEDVULNERABILITY_BASICVULNERABILITY_ENTERPRISEr   r   r   r    VulnerabilityModeValueValuesEnumr     s!    	 &'" r   r  r   r(   r   N)r   r   r   r   r   r   r6   r:  r  r:   r=  vulnerabilityModer   r   r   r   r  r     sP    INN ! !  
		2A	6$))*LaPr   r  c                       \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " SS5      r\R                  " S5      r\R                  " SS	5      r\R                  " S
SS9rSrg)ServiceMeshAnalysisMessagei   a  AnalysisMessage 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   rP  r(   r   Nr   r   r   r   r   r     r  r   r   r   Tr&   r   Nr   r   r   r   	ArgsValuer     ra  r   r  r   r(   ServiceMeshAnalysisMessageBaser0   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!  at  AnalysisMessageBase 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(   r0   r   N)
r   r   r   r   r   LEVEL_UNSPECIFIEDr  r  INFOr   r   r   r   LevelValueValuesEnumr  !  s     EGDr   r  r   r(   ServiceMeshTyper0   r   N)r   r   r   r   r   r   r6   r  r    documentationUrlr:   levelr   r   r   r   r   r   r  r  !  sP    Y^^  **1-


4a
8%			 11	5$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)ServiceMeshConditioni$!    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):(ServiceMeshCondition.CodeValueValuesEnumi4!  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(   r0   r?   r@   rA   r   r  r
  r  r  r  r  r  r  r
   rU  r  r  r   r  r  r                       r       !   "   #   $   %   &   '   (   )   *   +   ,   r$   .   /   0   1   2   3   4   r   N;r   r   r   r   r   r   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   r   r  4!  I   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)	,ServiceMeshCondition.SeverityValueValuesEnumi!  <  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(   r0   r   N
r   r   r   r   r   SEVERITY_UNSPECIFIEDr  r  r  r   r   r   r   SeverityValueValuesEnumrY  !      	 EGDr   r]  r   r(   r0   r?   r   Nr   r   r   r   r   r   r6   r   r]  r:   r   r    rS  documentationLinkseverityr   r   r   r   r  r  $!  s    I*INN I*V	   
		2A	6$!!!$'++A.  !: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)!ServiceMeshControlPlaneManagementi!  ar  Status of control plane management.

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

Fields:
  details: Explanation of state.
  implementation: Output only. Implementation of managed control plane.
  state: LifecycleState of control plane management.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	?ServiceMeshControlPlaneManagement.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(   r0   r   N)
r   r   r   r   r   IMPLEMENTATION_UNSPECIFIEDISTIODTRAFFIC_DIRECTORr  r   r   r   r   ImplementationValueValuesEnumrf  !  s     "#FHr   rj  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)6ServiceMeshControlPlaneManagement.StateValueValuesEnumi!  a_  LifecycleState 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(   r0   r?   r@   rA   r   r  r   Nr   r   r   r   r   r	  r[   FAILED_PRECONDITIONPROVISIONINGr  STALLEDNEEDS_ATTENTIONDEGRADEDDEPROVISIONINGr   r   r   r   r   rl  !  8    " #$HLFGOHNr   r   ServiceMeshStatusDetailsr   Tr&   r(   r0   r   N)r   r   r   r   r   r   r6   rj  r   r   rS  r:   implementationr   r   r   r   r   rd  rd  !  sd    inn Y^^ 8 ""#=q4P'&&'FJ.


4a
8%r   rd  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)ServiceMeshControlPlaneRevisioni"  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)	6ServiceMeshControlPlaneRevision.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(   r0   r   N
r   r   r   r   r   rx  rz  ry  r{  r   r   r   r   r|  rz  ,"      
 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)4ServiceMeshControlPlaneRevision.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(   r0   r?   r@   rA   r   r  r   Nrm  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)	3ServiceMeshControlPlaneRevision.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(   r0   r   N)
r   r   r   r   r   'CONTROL_PLANE_REVISION_TYPE_UNSPECIFIED	UNMANAGEDMANAGED_SERVICEMANAGED_LOCALr   r   r   r   r   r  ["  s    	 /0+IOMr   r   r   ru  r(   Tr&   r0   r?   r@   rA   r   r   N)r   r   r   r   r   r   r6   r|  r   r   r:   r}  r   rS  r    ownerrevisionr   r   r   r   r   r   r   rx  rx  "  s    0y~~ "Y^^ <INN    8!<'""#=q4P'



"%""1%(


4a
8%			2A	6$!!!$'r   rx  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)ServiceMeshDataPlaneManagementit"  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)3ServiceMeshDataPlaneManagement.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(   r0   r?   r@   rA   r   r  r   Nrm  r   r   r   r   r  "  rt  r   r   ru  r   Tr&   r(   r   Nr   r   r   r   r   r   r6   r   r   rS  r:   r   r   r   r   r   r  r  t"  sA    Y^^ 8 ""#=q4P'


4a
8%r   r  c                       \ rS rSrSr " S S\R                  5      r " S S\R                  5      r\R                  " SS5      r
\R                  " S5      r\R                  " S	5      r\R                  " SS
5      rSrg)ServiceMeshFeatureConditioni"  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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):/ServiceMeshFeatureCondition.CodeValueValuesEnumi"  a_  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(   r0   r?   r@   rA   r   r  r
  r  r  r  r  r  r  r
   rU  r  r  r   r  r  r  r  r  r	  r
  r  r  r  r   r  r  r  r  r  r  r  r  r  r  r  r  r  r$   r  r  r  r  r  r   r!  r   Nr"  r   r   r   r   r  "  rW  r   r   c                   (    \ rS rSrSrSrSrSrSrSr	g)	3ServiceMeshFeatureCondition.SeverityValueValuesEnumi:#  rZ  r   r   r(   r0   r   Nr[  r   r   r   r]  r  :#  r^  r   r]  r   r(   r0   r?   r   Nr_  r   r   r   r  r  "  rb  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  iP#  z**Service Mesh**: Spec for the fleet for the servicemesh feature

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

Fields:
  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   r   N)r   r   r   r   r   r   r6   r  r:   modernizationr   r   r   r   r  r  P#  s,    
Y^^ 
 %%&DaH-r   r  c                   `    \ rS rSrSr\R                  " SSSS9r\R                  " SSSS9rS	r	g
)r&  ij#  z**Service Mesh**: State for the whole Hub, as analyzed by the Service
Mesh Hub Controller.

Fields:
  analysisMessages: Output only. Results of running Service Mesh analyzers.
  conditions: Output only. List of conditions reported for this feature.
r  r   Tr&   r  r(   r   N)
r   r   r   r   r   r   r   analysisMessagesr   r   r   r   r   r&  r&  j#  s6     ++,H!VZ[%%&CQQUV*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\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/  iw#  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(   r0   r   Nr{  r   r   r   DefaultChannelValueValuesEnumr  #  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(   r0   r   N)
r   r   r   r   r   r1  r2  r3  MANAGEMENT_NOT_INSTALLEDr   r   r   r   r4  r  #  s!    
  r   r4  r   r(   r0   r?   r@   r   N)r   r   r   r   r   r   r6   r  r  r  r  r4  r:   	configApicontrolPlane	dataPlanedefaultChannelr9  r   r   r   r   r/  r/  w#  s    2 INN "% %inn $!).. !" !!"<a@)$$%BAF,!!"<a@)&&'FJ.""#>B*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)r  i#  a  **Service Mesh**: State for a single Membership, 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.
  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)	8ServiceMeshMembershipState.DefaultChannelValueValuesEnumi $  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(   r0   r   Nr{  r   r   r   r  r   $  r|  r   r  r  r   Tr&   r  r(   r0   rd  r?   rx  r@   r  rA   r   ServiceMeshMeshConnectivityr  r   N)r   r   r   r   r   r   r6   r  r   r  r   r    configApiVersioncontrolPlaneManagementcontrolPlaneRevisionsdataPlaneManagementr:   r  meshConnectivityr   r   r   r   r  r  #  s    .inn " ++,H!VZ[%%&<a$O***1-$112UWXY#001RTU`de!../OQRS&&'FJ.++,I1M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)r  i$  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)0ServiceMeshMeshConnectivity.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(   r0   r?   r@   rA   r   r  r   Nrm  r   r   r   r   r  '$  rt  r   r   ru  r   Tr&   r(   r   Nr  r   r   r   r  r  $  sA    	Y^^ 8 ""#=q4P'


4a
8%r   r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)ru  iG$  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   rS  r   r   r   r   ru  ru  G$  s)     
		q	!$!!!$'r   ru  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)r  iS$  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   r  r   r   r   r   r  r  S$  s)      
		q	!$%%a(+r   r  c                   b    \ rS rSrSr\R                  " SS5      r\R                  " S5      r	Sr
g)rk  ih$  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    rh  r   r   r   r   rk  rk  h$  s+    
 !!(A.&$$Q'*r   rk  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
)r  iy$  a|  Rollout stage.

Fields:
  clusterSelector: Optional. Filter members of fleets (above) to a subset of
    clusters. If not specified, all clusters in the fleets are selected.
  fleetProjects: Required. List of Fleet projects to select the clusters
    from. Expected format: projects/{project}
  soakDuration: Optional. Soak time after upgrading all the clusters in the
    stage.
r   r   r(   Tr&   r0   r   N)r   r   r   r   r   r   r   r  r    fleetProjectsr5  r   r   r   r   r  r  y$  s>    	 **+<a@/''D9-&&q),r   r  c                      \ rS rSrSr " S S\R                  5      r " S S\R                  5      r\R                  " SS5      r
\R                  " S5      r\R                  " SS	S
S9r\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                  " S5      r\R$                  " SSS9r\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                  " S5      rSrg)StandardQueryParametersi$  a  Query parameters accepted by all methods.

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

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

Values:
  json: Responses with Content-Type of application/json
  media: Media download with context-dependent Content-Type
  proto: Responses with Content-Type of application/x-protobuf
r   r   r(   r   N)	r   r   r   r   r   jsonmediaprotor   r   r   r   AltValueValuesEnumr  $  s     DEEr   r  c                        \ rS rSrSrSrSrSrg)-StandardQueryParameters.FXgafvValueValuesEnumi$  zFV1 error format.

Values:
  _1: v1 error format
  _2: v2 error format
r   r   r   N)r   r   r   r   r   _1_2r   r   r   r   FXgafvValueValuesEnumr  $  s     
B	
Br   r  r   r(   r0   r  )defaultr?   r@   rA   r   r  Tr
  r  r  r  r   N)r   r   r   r   r   r   r6   r  r  r:   f__xgafvr    access_tokenaltcallbackfieldsr   oauth_tokenr8   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   i$  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.CodeValueValuesEnumi$  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(   r0   r   N)
r   r   r   r   r   r   r  r   ri  r   r   r   r   r   r  $  s     	
BFGr   r   r   r(   r   Nr   r   r   r   r   r   r6   r   r:   r   r    r  r   r   r   r   r   r   $  s<    
INN $ 
		2A	6$%%a(+r   r   c                   :    \ rS rSrSr\R                  " SSS9rSrg)rq  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   rq  rq  $  s     %%a$7+r   rq  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Sr	g)r  i%  zTypeMeta is the type information needed for content unmarshalling of
Kubernetes resources in the manifest.

Fields:
  apiVersion: APIVersion of the resource (e.g. v1).
  kind: Kind of the resource (e.g. Deployment).
r   r(   r   N)
r   r   r   r   r   r   r    r  r  r   r   r   r   r  r  %  s)     $$Q'*			q	!$r   r  c                       \ rS rSrSr\R                  " SSSS9r\R                  " SSS9r	\R                  " SSS9r
S	rg
)r4  i%  a  The configuration used for the Rollout if triggered for UIPR. These
settings are used to adjust the wave distribution of the rollout and other
UIPR specific settings.

Fields:
  customWaves: Optional. The template for waves in the Rollout. If not set,
    the default is 5 waves progressing as 1: .55%, 2: 4%, 3: .29.2%, 4:
    57.4%, 5: 100%, with a minimum completion percentage of 100% for all
    waves. The last wave must have a upper bound of 100%.
  excludedMembershipNames: Optional. The excluded memberships from the
    rollout. If not set, all memberships will be considered for inclusion in
    the rollout (exclude tags on memberships will still be respected)
    Membership names are expected in the format of
    `projects//locations/{locations}/memberships/`.
  includeMembershipNames: Optional. The included memberships from the
    rollout. If not set, all memberships will be considered for inclusion in
    the rollout. If included in excluded_membership_names or tagged with
    excluded_clusters and included in included_membership_names, the rollout
    creation will error. Membership names are expected in the format of
    `projects//locations/{locations}/memberships/`
WaveTemplater   Tr&   r(   r0   r   N)r   r   r   r   r   r   r   customWavesr    excludedMembershipNamesincludeMembershipNamesr   r   r   r   r4  r4  %  sC    , &&~q4H+%11!dC$00TBr   r4  c                   b    \ rS rSrSr\R                  " SS5      r\R                  " S5      r	Sr
g)r  i-%  zRequest message for the `GkeHub.ValidateCreateMembership` method.

Fields:
  membership: Required. Membership resource to be created.
  membershipId: Required. Client chosen membership id.
r  r   r(   r   N)r   r   r   r   r   r   r   r   r    r  r   r   r   r   r  r  -%  s+     %%lA6*&&q),r   r  c                   <    \ rS rSrSr\R                  " SSSS9rSrg)	 ValidateCreateMembershipResponsei9%  zResponse message for the `GkeHub.ValidateCreateMembership` method.

Fields:
  validationResults: Wraps all the validator results.
ValidationResultr   Tr&   r   N)	r   r   r   r   r   r   r   validationResultsr   r   r   r   r  r  9%  s      ,,-?TRr   r  c                   >    \ rS rSrSr\R                  " SS5      rSrg)ValidateExclusivityResponseiC%  az  The response of exclusivity artifacts validation result status.

Fields:
  status: The validation result. * `OK` means that exclusivity is validated,
    assuming the manifest produced by GenerateExclusivityManifest is
    successfully applied. * `ALREADY_EXISTS` means that the Membership CRD
    is already owned by another Hub. See `status.message` for more
    information.
rI  r   r   N)	r   r   r   r   r   r   r   r   r   r   r   r   r  r  C%  s     !!"3Q7&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Srg	)
r  iQ%  aX  ValidationResults are results set by each validator running during
ValidateCreateMembership.

Enums:
  ValidatorValueValuesEnum: Validator type to validate membership with.

Fields:
  result: Additional information for the validation.
  success: Whether the validation is passed or not.
  validator: Validator type to validate membership with.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	)ValidationResult.ValidatorValueValuesEnumi^%  a  Validator type to validate membership with.

Values:
  VALIDATOR_TYPE_UNSPECIFIED: UNSPECIFIED validator.
  MEMBERSHIP_ID: MEMBERSHIP_ID validator validates that the membership_id
    is still available.
  CROSS_PROJECT_PERMISSION: CROSS_PROJECT_PERMISSION validator validates
    that the cross-project role binding for the service agent is in place.
  FLEET_ALLOWED_FOR_PROJECT_GUARDRAIL: FLEET_ALLOWED_FOR_PROJECT_GUARDRAIL
    validator validates that the fleet project is allowed for the project
    guardrail.
r   r   r(   r0   r   N)
r   r   r   r   r   VALIDATOR_TYPE_UNSPECIFIEDMEMBERSHIP_IDCROSS_PROJECT_PERMISSION#FLEET_ALLOWED_FOR_PROJECT_GUARDRAILr   r   r   r   ValidatorValueValuesEnumr  ^%  s      "#M *+'r   r   r   r(   r0   r   N)r   r   r   r   r   r   r6   r   r    resultr8   successr:   	validatorr   r   r   r   r  r  Q%  sL    
, ,$   #&""1%'!!"<a@)r   r  c                       \ rS rSrSr " S S\R                  5      r\R                  " S5      r	\R                  " SS5      rSrg)	r  iu%  a>  Config for version upgrade of clusters.

Enums:
  TypeValueValuesEnum: Optional. Type of version upgrade specifies which
    component should be upgraded.

Fields:
  desiredVersion: Optional. Desired version of the component.
  type: Optional. Type of version upgrade specifies which component should
    be upgraded.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	"VersionUpgrade.TypeValueValuesEnumi%  zOptional. Type of version upgrade specifies which component should be
upgraded.

Values:
  TYPE_UNSPECIFIED: Default value.
  TYPE_CONTROL_PLANE: Control plane upgrade.
  TYPE_NODE_POOL: Node pool upgrade.
  TYPE_CONFIG_SYNC: Config Sync upgrade.
r   r   r(   r0   r   N)
r   r   r   r   r   r   TYPE_CONTROL_PLANETYPE_NODE_POOLTYPE_CONFIG_SYNCr   r   r   r   r   r  %  s      Nr   r   r   r(   r   N)r   r   r   r   r   r   r6   r   r    desiredVersionr:   r   r   r   r   r   r  r  u%  s<    
INN  ((+.			2A	6$r   r  c                       \ rS rSrSr\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " S5      rSrg)	r  i%  a  WaveSchedule represents the schedule of a single rollout wave.

Fields:
  waveEndTime: Output only. The time at which the wave ends.
  waveNumber: Output only. The wave number to which this schedule applies.
  waveStartTime: Output only. The time at which the wave starts.
r   r(   r   r0   r   N)r   r   r   r   r   r   r    waveEndTimer   r   r   
waveNumberwaveStartTimer   r   r   r   r  r  %  sG     %%a(+%%a1B1B1H1HI*''*-r   r  c                   F   \ rS rSrSr " S S\R                  5      r\R                  " S\R                  R                  S9r\R                  " S\R                  R                  S9r\R                  " SS5      r\R                  " S	\R                  R                  S9rS
rg)r  i%  a  Template for a wave in the Rollout for custom wave configuration.

Enums:
  StragglerMigrationStrategyValueValuesEnum: Optional. The strategy for
    migrating stragglers after the wave is completed. If not set, the
    default is STRAGGLER_MIGRATION_STRATEGY_NO_MIGRATION.

Fields:
  minimumCompletionNumber: Optional. The minimum number of upgrades to be
    completed in the wave, before automatically proceeding to the next wave.
    If not set, the default is the size of the wave.
  minimumCompletionPercentage: Optional. The minimum number of upgrades as a
    percentage of the wave size to be completed in the wave, before
    automatically proceeding to the next wave. If not set, the default is
    100%.
  stragglerMigrationStrategy: Optional. The strategy for migrating
    stragglers after the wave is completed. If not set, the default is
    STRAGGLER_MIGRATION_STRATEGY_NO_MIGRATION.
  upperBoundPercentage: Required. The total percentage of clusters that
    should be finished by the end of the wave (inclusive of all previous
    waves). upper_bound_percentage must be monotonically increasing wave to
    wave and the final wave must be 100.
c                   $    \ rS rSrSrSrSrSrSrg)6WaveTemplate.StragglerMigrationStrategyValueValuesEnumi%  a  Optional. The strategy for migrating stragglers after the wave is
completed. If not set, the default is
STRAGGLER_MIGRATION_STRATEGY_NO_MIGRATION.

Values:
  STRAGGLER_MIGRATION_STRATEGY_UNSPECIFIED: Unspecified straggler
    migration strategy.
  STRAGGLER_MIGRATION_STRATEGY_NO_MIGRATION: No migration of stragglers.
  STRAGGLER_MIGRATION_STRATEGY_LAST_WAVE: Migrate stragglers to the last
    wave of the rollout.
r   r   r(   r   N)	r   r   r   r   r   (STRAGGLER_MIGRATION_STRATEGY_UNSPECIFIED)STRAGGLER_MIGRATION_STRATEGY_NO_MIGRATION&STRAGGLER_MIGRATION_STRATEGY_LAST_WAVEr   r   r   r   )StragglerMigrationStrategyValueValuesEnumr  %  s    
 01,01--.*r   r  r   r   r(   r0   r?   r   N)r   r   r   r   r   r   r6   r  r   r   r   minimumCompletionNumberr  r  minimumCompletionPercentager:   stragglerMigrationStrategyupperBoundPercentager   r   r   r   r  r  %  s    0/).. /  &221i>O>O>U>UV ) 4 4Q	@Q@Q@W@W X(223^`ab"--a9J9J9P9PQr   r  c                   <    \ rS rSrSr\R                  " S5      rSrg)r  i%  a(  **WorkloadIdentity**: Global feature specification.

Fields:
  scopeTenancyPool: Pool to be used for Workload Identity. This pool in
    trust-domain mode is used with Fleet Tenancy, so that sameness can be
    enforced. ex:
    projects/example/locations/global/workloadidentitypools/custompool
r   r   N)	r   r   r   r   r   r   r    scopeTenancyPoolr   r   r   r   r  r  %  s     **1-r   r  c                   H   \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " S5       " S S\R                  5      5       r
\R                  " S5       " S S	\R                  5      5       r\R                  " S5       " S
 S\R                  5      5       r\R                  " SS5      r\R                  " SS5      r\R                   " S5      r\R                   " S5      r\R                  " S	S5      r\R                  " SS5      rSrg)r(  i%  a
  **WorkloadIdentity**: Global feature state.

Messages:
  NamespaceStateDetailsValue: The state of the IAM namespaces for the fleet.
  NamespaceStatesValue: Deprecated, this field will be erased after code is
    changed to use the new field.
  WorkloadIdentityPoolStateDetailsValue: The state of the Workload Identity
    Pools for the fleet.
  WorkloadIdentityPoolStatesValue: Deprecated, this field will be erased
    after code is changed to use the new field.

Fields:
  namespaceStateDetails: The state of the IAM namespaces for the fleet.
  namespaceStates: Deprecated, this field will be erased after code is
    changed to use the new field.
  scopeTenancyWorkloadIdentityPool: The full name of the scope-tenancy pool
    for the fleet.
  workloadIdentityPool: The full name of the svc.id.goog pool for the fleet.
  workloadIdentityPoolStateDetails: The state of the Workload Identity Pools
    for the fleet.
  workloadIdentityPoolStates: Deprecated, this field will be erased after
    code is changed to use the new field.
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	)
7WorkloadIdentityFeatureState.NamespaceStateDetailsValuei%  zThe state of the IAM namespaces for the fleet.

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

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

Fields:
  key: Name of the additional property.
  value: A WorkloadIdentityNamespaceStateDetail attribute.
r   $WorkloadIdentityNamespaceStateDetailr(   r   Nr   r   r   r   r   r   &  s,    
 !!!$c$$%KQOer   r   r   Tr&   r   Nr   r   r   r   NamespaceStateDetailsValuer  %  s4    		PY.. 	P %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	)
1WorkloadIdentityFeatureState.NamespaceStatesValuei&  a  Deprecated, this field will be erased after code is changed to use the
new field.

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

Fields:
  additionalProperties: Additional properties of type NamespaceStatesValue
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)	DWorkloadIdentityFeatureState.NamespaceStatesValue.AdditionalPropertyi&  zAn additional property for a NamespaceStatesValue object.

Enums:
  ValueValueValuesEnum:

Fields:
  key: Name of the additional property.
  value: A ValueValueValuesEnum attribute.
c                   $    \ rS rSrSrSrSrSrSrg)YWorkloadIdentityFeatureState.NamespaceStatesValue.AdditionalProperty.ValueValueValuesEnumi*&  a  ValueValueValuesEnum enum type.

Values:
  NAMESPACE_STATE_UNSPECIFIED: Unknown state.
  NAMESPACE_STATE_OK: The Namespace was created/updated successfully.
  NAMESPACE_STATE_ERROR: The Namespace was not created/updated
    successfully. The error message is in the description field.
r   r   r(   r   N	r   r   r   r   r   NAMESPACE_STATE_UNSPECIFIEDNAMESPACE_STATE_OKNAMESPACE_STATE_ERRORr   r   r   r   ValueValueValuesEnumr(  *&  s    	 '(# !r   r-  r   r(   r   Nr   r   r   r   r   r   r6   r-  r    r   r:   r   r   r   r   r   r   r&  &  s<    
" " !!!$c!!"8!<er   r   r   Tr&   r   Nr   r   r   r   NamespaceStatesValuer$  &  s2    	=Y.. =6 %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	)
BWorkloadIdentityFeatureState.WorkloadIdentityPoolStateDetailsValuei<&  a  The state of the Workload Identity Pools for the fleet.

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

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

Fields:
  key: Name of the additional property.
  value: A WorkloadIdentityWorkloadIdentityPoolStateDetail attribute.
r   /WorkloadIdentityWorkloadIdentityPoolStateDetailr(   r   Nr   r   r   r   r   r3  I&  s-    
 !!!$c$$%VXYZer   r   r   Tr&   r   Nr   r   r   r   %WorkloadIdentityPoolStateDetailsValuer1  <&  s4    	
[Y.. 
[ %112FTXYr   r5  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
<WorkloadIdentityFeatureState.WorkloadIdentityPoolStatesValueiW&  a  Deprecated, this field will be erased after code is changed to use the
new field.

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

Fields:
  additionalProperties: Additional properties of type
    WorkloadIdentityPoolStatesValue
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)	OWorkloadIdentityFeatureState.WorkloadIdentityPoolStatesValue.AdditionalPropertyie&  zAn additional property for a WorkloadIdentityPoolStatesValue object.

Enums:
  ValueValueValuesEnum:

Fields:
  key: Name of the additional property.
  value: A ValueValueValuesEnum attribute.
c                   $    \ rS rSrSrSrSrSrSrg)dWorkloadIdentityFeatureState.WorkloadIdentityPoolStatesValue.AdditionalProperty.ValueValueValuesEnumip&  af  ValueValueValuesEnum enum type.

Values:
  WORKLOAD_IDENTITY_POOL_STATE_UNSPECIFIED: Unknown state.
  WORKLOAD_IDENTITY_POOL_STATE_OK: The Workload Identity Pool was
    created/updated successfully.
  WORKLOAD_IDENTITY_POOL_STATE_ERROR: The Workload Identity Pool was
    not created/updated successfully. The error message is in the
    description field.
r   r   r(   r   N	r   r   r   r   r   (WORKLOAD_IDENTITY_POOL_STATE_UNSPECIFIEDWORKLOAD_IDENTITY_POOL_STATE_OK"WORKLOAD_IDENTITY_POOL_STATE_ERRORr   r   r   r   r-  r;  p&  s    		 450*+'-.*r   r-  r   r(   r   Nr.  r   r   r   r   r9  e&  s<    
/ / !!!$c!!"8!<er   r   r   Tr&   r   Nr   r   r   r   WorkloadIdentityPoolStatesValuer7  W&  s2    
=Y.. =: %112FTXYr   r@  r   r(   r0   r?   r@   rA   r   N)r   r   r   r   r   r   r   r   r   r"  r/  r5  r@  r   namespaceStateDetailsnamespaceStatesr    rG   rH    workloadIdentityPoolStateDetailsworkloadIdentityPoolStatesr   r   r   r   r(  r(  %  s>   0 !!"89Z9#4#4 Z :Z2 !!"89'ZY.. 'Z :'ZR !!"89Zi.?.? Z :Z4 !!"89*Z	(9(9 *Z :*ZX $001MqQ**+A1E/%.%:%:1%=""..q1%.%;%;<cef%g"(556WYZ[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)	+WorkloadIdentityIdentityProviderStateDetaili&  a  IdentityProviderStateDetail represents the state of an Identity
Provider.

Enums:
  CodeValueValuesEnum: The state of the Identity Provider.

Fields:
  code: The state of the Identity Provider.
  description: A human-readable description of the current state or returned
    error.
c                   $    \ rS rSrSrSrSrSrSrg)?WorkloadIdentityIdentityProviderStateDetail.CodeValueValuesEnumi&  aQ  The state of the Identity Provider.

Values:
  IDENTITY_PROVIDER_STATE_UNSPECIFIED: Unknown state.
  IDENTITY_PROVIDER_STATE_OK: The Identity Provider was created/updated
    successfully.
  IDENTITY_PROVIDER_STATE_ERROR: The Identity Provider was not
    created/updated successfully. The error message is in the description
    field.
r   r   r(   r   N	r   r   r   r   r   #IDENTITY_PROVIDER_STATE_UNSPECIFIEDIDENTITY_PROVIDER_STATE_OKIDENTITY_PROVIDER_STATE_ERRORr   r   r   r   r   rH  &  s    	 +,'!"$%!r   r   r   r(   r   Nr  r   r   r   rF  rF  &  s<    
&INN & 
		2A	6$%%a(+r   rF  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S	5      r\R                   " SS
5      rSrg)r  i&  a  **WorkloadIdentity**: The membership-specific state for WorkloadIdentity
feature.

Enums:
  StateValueValuesEnum: Output only. Deprecated, this field will be erased
    after code is changed to use the new field.

Messages:
  IdentityProviderStateDetailsValue: The state of the Identity Providers
    corresponding to the membership.

Fields:
  description: Deprecated, this field will be erased after code is changed
    to use the new field.
  identityProviderStateDetails: The state of the Identity Providers
    corresponding to the membership.
  state: Output only. Deprecated, this field will be erased after code is
    changed to use the new field.
c                   $    \ rS rSrSrSrSrSrSrg)4WorkloadIdentityMembershipState.StateValueValuesEnumi&  a  Output only. Deprecated, this field will be erased after code is
changed to use the new field.

Values:
  IDENTITY_PROVIDER_STATE_UNSPECIFIED: Unknown state.
  IDENTITY_PROVIDER_STATE_OK: The Identity Provider was created/updated
    successfully.
  IDENTITY_PROVIDER_STATE_ERROR: The Identity Provider was not
    created/updated successfully. The error message is in the description
    field.
r   r   r(   r   NrI  r   r   r   r   rO  &  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	)
AWorkloadIdentityMembershipState.IdentityProviderStateDetailsValuei&  a  The state of the Identity Providers corresponding to the membership.

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

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

Fields:
  key: Name of the additional property.
  value: A WorkloadIdentityIdentityProviderStateDetail attribute.
r   rF  r(   r   Nr   r   r   r   r   rS  &  s-    
 !!!$c$$%RTUVer   r   r   Tr&   r   Nr   r   r   r   !IdentityProviderStateDetailsValuerQ  &  s4    	
WY.. 
W %112FTXYr   rT  r   r(   r0   r   N)r   r   r   r   r   r   r6   r   r   r   r   rT  r    r  r   identityProviderStateDetailsr:   r   r   r   r   r   r  r  &  s    (&Y^^ &  !!"89Z)*;*; Z :Z4 %%a(+!*!7!78[]^!_


4a
8%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&  a  NamespaceStateDetail represents the state of a IAM namespace.

Enums:
  CodeValueValuesEnum: The state of the IAM namespace.

Fields:
  code: The state of the IAM namespace.
  description: A human-readable description of the current state or returned
    error.
c                   $    \ rS rSrSrSrSrSrSrg)8WorkloadIdentityNamespaceStateDetail.CodeValueValuesEnumi&  a  The state of the IAM namespace.

Values:
  NAMESPACE_STATE_UNSPECIFIED: Unknown state.
  NAMESPACE_STATE_OK: The Namespace was created/updated successfully.
  NAMESPACE_STATE_ERROR: The Namespace was not created/updated
    successfully. The error message is in the description field.
r   r   r(   r   Nr)  r   r   r   r   rX  &  s     #$r   r   r   r(   r   Nr  r   r   r   r!  r!  &  s<    	INN  
		2A	6$%%a(+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)	r4  i'  a=  WorkloadIdentityPoolStateDetail represents the state of the Workload
Identity Pools for the fleet.

Enums:
  CodeValueValuesEnum: The state of the Workload Identity Pool.

Fields:
  code: The state of the Workload Identity Pool.
  description: A human-readable description of the current state or returned
    error.
c                   $    \ rS rSrSrSrSrSrSrg)CWorkloadIdentityWorkloadIdentityPoolStateDetail.CodeValueValuesEnumi'  ao  The state of the Workload Identity Pool.

Values:
  WORKLOAD_IDENTITY_POOL_STATE_UNSPECIFIED: Unknown state.
  WORKLOAD_IDENTITY_POOL_STATE_OK: The Workload Identity Pool was
    created/updated successfully.
  WORKLOAD_IDENTITY_POOL_STATE_ERROR: The Workload Identity Pool was not
    created/updated successfully. The error message is in the description
    field.
r   r   r(   r   Nr<  r   r   r   r   r[  '  s    	 01,&'#)*&r   r   r   r(   r   Nr  r   r   r   r4  r4  '  s<    
+INN + 
		2A	6$%%a(+r   r4  c                       \ rS rSrSrSrg)r  i.'  z**WorkloadMigration**: The Hub-wide input for the WorkloadMigration
feature. This is currently empty, but is used to restrict API visibility.
r   Nr   r   r   r   r  r  .'  r0  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#   r%   r=   rJ   rU   rb   rj   rl   rn   rq   r}   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r  r!  r+  r5  r;  rA  rc  rr  ru  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r)  r*  r-  r,  r<  r  r=  r5  rV  rM  r>  rm  rq  r  r  r  r  r  r  r  r  r  r  r  r  rd   r  r  r  r'  r  r  r  r  r  r"  r$  r   r!  r  r/  r2  r,  r9  r;  r?  rB  rE  rI  rQ  rU  rZ  r`  rc  rg  rj  rp  rv  ry  r|  r~  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r	  r  r  r  r  r  r  r!  r#  r%  r'  r*  r,  r.  r1  r3  r5  r7  r9  r;  r=  r?  rA  rC  rE  rG  rI  rU  r  r#  rf  r-  rz  r|  r~  r  r  r  r  r  r  r  r.  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r   r  r  r  r  r  r  r  r  r  r  r  r.  r3  r  r  re  rR  r  r  r  rT  r}  rS  rk  r  r  r	  r$  rv  r~  r  rl  r  r  rw  r  r  r^   r  r  r0  r  r  r  r  r  r  rA  r9  r&  r:  r  r  r%  rx  r  ra  rW  r  r  r  r  rV  r
  r  r  r  r  r  r  r  r  r  r  r  r  r  r  rd  rx  r  r  r  r&  r/  r  r  ru  r  rk  r  r  r   rq  r  r  r4  r  r  r  r  r  r  r  r  r(  rF  r  r!  r4  r  AddCustomJsonFieldMappingAddCustomJsonEnumMappingr  r   r   r   <module>rf     s  
 ' < % ( .)"3"3 .C9#4#4 C*y(( *%)## %:!=Y&& !=H'2	!! '2TK)"3"3 K<M	 1 1 M>V"i V"r=Y.. =39,, 3G9#4#4 G0K	)) 0Kf%y00 %<+i'' +3NI%% 3Nl;i// ;*16y00 16h%y00 %(y/@/@ ("
[9+<+< 
[By'8'8 B'BI$5$5 'BT$i&7&7 $	Bi.?.? 	BaI$5$5 a"	%9#4#4 	%;i// ;.46y00 46nI()"3"3 I(XQ	)) QDO** O4Q):): Q&7i// 78&** &@3	!! @3F67I$5$5 67r%9+<+< %"&%):): &%RQ)*;*; Q&Y%6%6 &=I$5$5 =>,i&7&7 ,'*!2!2 '*Tu;	0A0A u;p*i&7&7 *jKi&7&7 jKZ$	(9(9 $8+	(9(9 +$1):): 1"(I$5$5 ( CS	0A0A CSL+	 1 1 +B%y'8'8 %&	0A0A &159J9J 15h	Ty/@/@ 	T	!1B1B 	!*9#4#4 *1%Y%6%6 1%h]i&7&7 ]:+	 1 1 +2%I$5$5 %B!(y'8'8 !(H9	0A0A 9:W1B1B W:QI,=,= Q%i.?.? %]	 1 1 ]1'	 1 1 1'h
/9,, 
/$Y&& $6'Y.. '6#)## #!=	)) !=H/Y.. /M9,, M('Y.. '$*)## *I ;i'' ;@!#9 !#HI)i I)X$99,, $9N"Q)## "QJ&(9$$ &(R
MI%% 
M;(I ;(|7)++ 7:	)Y%6%6 	)
OI$5$5 
O
`Y%6%6 
`V9;L;L V@	_y7H7H 	_\):K:K \Vi&7&7 Vy'8'8 	(9(9 7i&7&7 72	Ni&7&7 	N))*;*; ).I4E4E .")++ "*"" * 3I4E4E 3*'93D3D '6'93D3D '659J9J 543	0A0A 3 31B1B 3D()2C2C (6I9J9J I Uy?P?P U 
31B1B 
311B1B 11i.?.? 13y/@/@ 3*(	0A0A ("1	(9(9 1'):): '63i>O>O 3"1i>O>O 119;L;L 13I<M<M 3.(Y=N=N ("'i6G6G '@'i6G6G '6*&yGXGX *&Z19K\K\ 1(5I<M<M 54193D3D 139J9J 343I4E4E 3>3I<M<M 36(Y5F5F (6/iFWFW /.	1iFWFW 	1/enevev /.19CTCT 13IDUDU 3((YEVEV ($II<M<M I U)BSBS U ai>O>O a39CTCT 3$3Y5F5F 3(1Y5F5F 11)2C2C 1393D3D 3&(I4E4E (/YEVEV /,1YEVEV 11)BSBS 139CTCT 3((IDUDU ($
1Y5F5F 
11Y5F5F 11)2C2C 1393D3D 30/9;L;L /$19;L;L 11	8I8I 139J9J 30():K:K ( 193D3D 1'93D3D '"'93D3D '.1	0A0A 131B1B 30I)2C2C IK93D3D K%1B1B % 11B1B 15y7H7H 541i.?.? 16):K:K 643	8I8I 3&3y/@/@ 3&.9;L;L .*19;L;L 11	8I8I 139J9J 3(():K:K ((	0A0A (/ARAR /,1ARAR 11i>O>O 13y?P?P 3((	@Q@Q ($Iy7H7H I UY=N=N U 0%i'' 0%f[9i// [9|GI-- GY.. 	Fy(( 	FGy00 G	 1 1 G)++ G9,, F	 1 1 F.'9#4#4 '6,):): ,&)"3"3 &)!2!2 ),-I,=,= -@	 1 1 @(
^I$5$5 
^9Y%6%6 9@&)	 1 1 &)RI(	 1 1 I(X")"3"3 "(	\)*;*; 	\&9+<+< &",	 1 1 ,<I** ID!A** !AH8)*;*; 8$89#4#4 8"B9,, B+** +
+I-- 
+8Y%6%6 8"8Y->-> 8"8i// 8"+Y.. +8Y.. 8$=)"3"3 =Q9#4#4 Q$I-- $(
EY.. 
EQ9#4#4 Q
A9,, 
AJ)"3"3 JQ	(9(9 Q=** =8i&7&7 8"M"y   M"`>	!! >E9,, E o)"" o)d7(	)) 7(t7i&7&7 7> =**  =F!EI-- !EH"SY.. "SJYY&& Y87i'' 7@di// d'y(( ':*	)) *,.Y%6%6 .B])	!! ])@II$5$5 ID+Y%6%6 +y'8'8 	(9(9 7i// 7<'*I%% '*Ti8	!! i8X"	)) "47Y 780)++ 0SGY SGl	"I%% 	"?	(9(9 ?b7	 1 1 b7J%Y%6%6 %g9i&7&7 g9TWy'8'8 W:C9Y%6%6 C9L+W	(9(9 +W\-U):): -U`!+y7H7H !+H	$9#4#4 	$G9+<+< GGI,=,= G8#!2!2 # ;#i'' ;#|?)*;*; ?9+<+< Y->-> .Ri.?.? .Rb(93D3D (@7I$5$5 7>:"	!! :"z&y(( & )i'' )4
+9,, 
+K9 KDr@i r@jNY.. N,:(i'' :(z%99$$ %9P59I%% 59p289 28jCy   C[(I [(|	@y(( 	@4	)) 47)++ 7:.QI-- .Qb3:!2!2 3:l6Y%6%6 6Dn?9,, n?b;9	(9(9 ;9|^%i&7&7 ^%B(9Y%6%6 (9Vn?)"3"3 n?bIY.. I4
Wi// 
WnC	 1 1 nCb0N!2!2 0Nf)9)"3"3 )9X	%y00 	%)i'' )*()++ ("*I *"<.i// <.~ )Y  )F
8	 1 1 
88!2!2 8
"y   
"C	)) C8	*i&7&7 	*Sy'8'8 S8)"3"3 8!Ay(( !AH7Y&& 7@+9$$ +,R9$$ ,R^
.)"3"3 
.j\9#4#4 j\Z))2C2C )@B9i&7&7 B9J)9+<+< ):)i6G6G )@9#4#4  	 " "%  " "Z4  ! !114>  ! !114>  " "68XZz|  " "9;[]}  " "46VXxzr   