
    R                       d Z ddlmZ ddlmZ ddlmZ ddlmZ dZ	 G d dej                        Z G d	 d
ej                        Z G d dej                        Z G d dej                        Z G d dej                        Z G d dej                        Z G d dej                        Z G d dej                        Z G d dej                        Z G d dej                        Z G d dej                        Z G d dej                        Z G d d ej                        Z G d! d"ej                        Z G d# d$ej                        Z G d% d&ej                        Z G d' d(ej                        Z G d) d*ej                        Z G d+ d,ej                        Z G d- d.ej                        Z G d/ d0ej                        Z G d1 d2ej                        Z  G d3 d4ej                        Z! G d5 d6ej                        Z" G d7 d8ej                        Z# G d9 d:ej                        Z$ G d; d<ej                        Z% G d= d>ej                        Z& G d? d@ej                        Z' G dA dBej                        Z( G dC dDej                        Z) G dE dFej                        Z* G dG dHej                        Z+ G dI dJej                        Z, G dK dLej                        Z- G dM dNej                        Z. G dO dPej                        Z/ G dQ dRej                        Z0 G dS dTej                        Z1 G dU dVej                        Z2 G dW dXej                        Z3 G dY dZej                        Z4 G d[ d\ej                        Z5 G d] d^ej                        Z6 G d_ d`ej                        Z7 G da dbej                        Z8 G dc ddej                        Z9 G de dfej                        Z: G dg dhej                        Z; G di djej                        Z< G dk dlej                        Z= G dm dnej                        Z> G do dpej                        Z? G dq drej                        Z@ G ds dtej                        ZA G du dvej                        ZB G dw dxej                        ZC G dy dzej                        ZD G d{ d|ej                        ZE G d} d~ej                        ZF G d dej                        ZG G d dej                        ZH G d dej                        ZI G d dej                        ZJ G d dej                        ZK G d dej                        ZL G d dej                        ZM G d dej                        ZN G d dej                        ZO G d dej                        ZP G d dej                        ZQ G d dej                        ZR G d dej                        ZS G d dej                        ZT G d dej                        ZU G d dej                        ZV G d dej                        ZW G d dej                        ZX G d dej                        ZY G d dej                        ZZ G d dej                        Z[ G d dej                        Z\ G d dej                        Z] G d dej                        Z^ G d dej                        Z_ G d dej                        Z` G d dej                        Za G d dej                        Zb G d dej                        Zc G d dej                        Zd G d dej                        Ze G d dej                        Zf G d dej                        Zg G d dej                        Zh G dÄ dej                        Zi G dń dej                        Zj G dǄ dej                        Zk G dɄ dej                        Zl G d˄ dej                        Zm G d̈́ dej                        Zn G dτ dej                        Zo G dф dej                        Zp G dӄ dej                        Zq G dՄ dej                        Zr G dׄ dej                        Zs G dل dej                        Zt G dۄ dej                        Zu ej                  etddޫ        ej                  eidd        ej                  eij                  dd        ej                  eij                  dd       y)zoGenerated message classes for saasservicemgmt version v1beta1.

Model, deploy, and operate your SaaS at scale.
    )absolute_import)messages)encoding)extra_typessaasservicemgmtc                       e Zd ZdZ ej
                  dej                  j                        Z ej                  d      Z
y)	Aggregatea%  Represents the aggregation of a set of population of like records by a
  certain group. For example, a collection of unit counts can be aggregated
  and grouped by their state.

  Fields:
    count: Required. Number of records in the group.
    group: Required. Group by which to aggregate.
     variant   N)__name__
__module____qualname____doc__	_messagesIntegerFieldVariantINT32countStringFieldgroup     elib/googlecloudsdk/generated_clients/apis/saasservicemgmt/v1beta1/saasservicemgmt_v1beta1_messages.pyr	   r	      s;     !)
 
 I,=,=,C,C
D%
)


"%r   r	   c                   |    e Zd ZdZ ej
                  d      Z ej
                  d      Z ej
                  d      Zy)	Blueprinta  Blueprints are OCI Images that contain all of the artifacts needed to
  provision a unit. Metadata such as, type of the engine used to actuate the
  blueprint (e.g. terraform, helm etc) and version will come from the image
  manifest. If the hostname is omitted, it will be assumed to be the regional
  path to Artifact Registry (eg. us-east1-docker.pkg.dev).

  Fields:
    engine: Output only. Type of the engine used to actuate the blueprint.
      e.g. terraform, helm etc.
    package: Optional. Immutable. URI to a blueprint used by the Unit
      (required unless unitKind or release is set).
    version: Output only. Version metadata if present on the blueprint.
  r
   r      N)	r   r   r   r   r   r   enginepackageversionr   r   r   r   r      s?     !9  #&!I!!!$'!I!!!$'r   r   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)
DependencyzDependency represent a single dependency with another unit kind by
  alias.

  Fields:
    alias: Required. An alias for the dependency. Used for input variable
      mapping.
    unitKind: Required. Immutable. The unit kind of the dependency.
  r
   r   N)r   r   r   r   r   r   aliasunitKindr   r   r   r#   r#   3   s-      )


"%"Y""1%(r   r#   c                       e Zd ZdZy)DeprovisionzDeprovision is the unit operation that deprovision the underlying
  resources represented by a Unit. Can only execute if the Unit is currently
  provisioned.
  Nr   r   r   r   r   r   r   r'   r'   A   s    r   r'   c                       e Zd ZdZy)Emptya!  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); }
  Nr(   r   r   r   r*   r*   I   s    r   r*   c                       e Zd ZdZ ej
                  dej                  j                        Z ej
                  dej                  j                        Z	y)ErrorBudgeta  The configuration for error budget. If the number of failed units
  exceeds max(allowed_count, allowed_ratio * total_units), the rollout will be
  paused.

  Fields:
    allowedCount: Optional. The maximum number of failed units allowed in a
      location without pausing the rollout.
    allowedPercentage: Optional. The maximum percentage of units allowed to
      fail (0, 100] within a location without pausing the rollout.
  r
   r   r   N)
r   r   r   r   r   r   r   r   allowedCountallowedPercentager   r   r   r,   r,   R   sJ    	 (''93D3D3J3JK,,i,,Q	8I8I8O8OPr   r,   c                   ^    e Zd ZdZ ej
                  d      Z ej                  ddd      Zy)EvaluationSpeczEvaluationSpec holds rules for evaluating the value of a flag.

  Fields:
    defaultTarget: Required. Default variant or allocation of the flag.
    variants: Optional. A list of variants.
  r
   r   r   TrepeatedN)	r   r   r   r   r   r   defaultTargetMessageFieldvariantsr   r   r   r0   r0   b   s1     ()''*-#Y##Iq4@(r   r0   c                      e Zd ZdZ G d dej
                        Z ej                  d       G d dej                               Z
 ej                  d       G d dej                               Z ej                  dd	      Z ej                  d
      Z ej                  d      Z ej                  d      Z ej                  dd      Z ej                  d      Z ej                  dd      Z ej                  d      Z ej                  d      Z ej                  d      Z ej                  d      Z ej2                  dd      Zy)Flaga
  Represents a single Flag.

  Enums:
    ValueTypeValueValuesEnum: Required. Immutable. Flag value type.

  Messages:
    AnnotationsValue: Optional. Annotations is an unstructured key-value map
      stored with a resource that may be set by external tools to store and
      retrieve arbitrary metadata. They are not queryable and should be
      preserved when modifying objects. More info:
      https://kubernetes.io/docs/user-guide/annotations
    LabelsValue: Optional. The labels on the resource, which can be used for
      categorization. similar to Kubernetes resource labels.

  Fields:
    annotations: Optional. Annotations is an unstructured key-value map stored
      with a resource that may be set by external tools to store and retrieve
      arbitrary metadata. They are not queryable and should be preserved when
      modifying objects. More info: https://kubernetes.io/docs/user-
      guide/annotations
    createTime: Output only. The timestamp when the resource was created.
    description: Optional. Description of the flag. Max length: 500 bytes.
    etag: Output only. An opaque value that uniquely identifies a version or
      generation of a resource. It can be used to confirm that the client and
      server agree on the ordering of a resource being written.
    evaluationSpec: Optional. Specification of how the flag value should be
      evaluated. If a bool flag is created without an evaluation_spec
      specified, two default variants, "Enabled" (with bool_value = true) and
      "Disabled" (with bool_value = false), are created by default, and
      "Disabled" is set as the default_target.
    key: Required. Immutable. Flag key used in runtime evaluation APIs
      (OpenFeature). Max length: 256 bytes.
    labels: Optional. The labels on the resource, which can be used for
      categorization. similar to Kubernetes resource labels.
    name: Identifier. The resource name (full URI of the resource) following
      the standard naming scheme:
      "projects/{project}/locations/{location}/flags/{flag_id}"
    uid: Output only. The unique identifier of the resource. UID is unique in
      the time and space for this resource within the scope of the service. It
      is typically generated by the server on successful creation of a
      resource and must not be changed. UID is used to uniquely identify
      resources with resource name reuses. This should be a UUID4.
    unitKind: Required. Immutable. UnitKind that can consume this flag.
    updateTime: Output only. The timestamp when the resource was last updated.
      Any change to the resource made by users must refresh this value.
      Changes to a resource made by the service should refresh this value.
    valueType: Required. Immutable. Flag value type.
  c                   $    e Zd ZdZdZdZdZdZdZy)Flag.ValueTypeValueValuesEnuma:  Required. Immutable. Flag value type.

    Values:
      FLAG_VALUE_TYPE_UNSPECIFIED: <no description>
      FLAG_VALUE_TYPE_BOOL: Boolean flag value type.
      FLAG_VALUE_TYPE_INT: Integer flag value type.
      FLAG_VALUE_TYPE_STRING: String flag value type.
      FLAG_VALUE_TYPE_DOUBLE: Double flag type.
    r   r
   r   r      N)	r   r   r   r   FLAG_VALUE_TYPE_UNSPECIFIEDFLAG_VALUE_TYPE_BOOLFLAG_VALUE_TYPE_INTFLAG_VALUE_TYPE_STRINGFLAG_VALUE_TYPE_DOUBLEr   r   r   ValueTypeValueValuesEnumr9      s'     #$r   r@   additionalPropertiesc                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)Flag.AnnotationsValue  Optional. Annotations is an unstructured key-value map stored with a
    resource that may be set by external tools to store and retrieve arbitrary
    metadata. They are not queryable and should be preserved when modifying
    objects. More info: https://kubernetes.io/docs/user-guide/annotations

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

    Fields:
      additionalProperties: Additional properties of type AnnotationsValue
    c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)(Flag.AnnotationsValue.AdditionalPropertyAn additional property for a AnnotationsValue object.

      Fields:
        key: Name of the additional property.
        value: A string attribute.
      r
   r   Nr   r   r   r   r   r   keyvaluer   r   r   AdditionalPropertyrF      -    
 "I!!!$c#i##A&er   rK   r
   Tr1   N	r   r   r   r   r   MessagerK   r4   rA   r   r   r   AnnotationsValuerC      4    	'Y.. 	' 29112FTXYr   rO   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)Flag.LabelsValue(  Optional. The labels on the resource, which can be used for
    categorization. similar to Kubernetes resource labels.

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

    Fields:
      additionalProperties: Additional properties of type LabelsValue
    c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)#Flag.LabelsValue.AdditionalPropertyAn additional property for a LabelsValue object.

      Fields:
        key: Name of the additional property.
        value: A string attribute.
      r
   r   NrH   r   r   r   rK   rU      rL   r   rK   r
   Tr1   NrM   r   r   r   LabelsValuerR      4    	'Y.. 	' 29112FTXYr   rW   r
   r   r   r:   r0               	   
         N)r   r   r   r   r   Enumr@   r   MapUnrecognizedFieldsrN   rO   rW   r4   annotationsr   
createTimedescriptionetagevaluationSpecrI   labelsnameuidr%   
updateTime	EnumField	valueTyper   r   r   r7   r7   n   sa   /b   "8!!"89Z** Z :Z6 "8!!"89ZI%% Z :Z0 '	&&'91=+$y$$Q'*%	%%a(+			q	!$)9))*:A>.	a #!9!!-3&			q	!$	a #"Y""2&($y$$R(*!i!!"<bA)r   r7   c                   ,   e Zd ZdZ ej
                  d       G d dej                               Z ej
                  d       G d dej                               Z	 ej                  dd      Z ej                  d      Z ej                  d	      Z ej                  d
d      Z ej                  dd      Z ej                  d      Z ej                  dd      Z ej                  d      Z ej                  d      Z ej                  d      Zy)FlagReleasea	  A collection of FlagRevisions.

  Messages:
    AnnotationsValue: Optional. Annotations is an unstructured key-value map
      stored with a resource that may be set by external tools to store and
      retrieve arbitrary metadata. They are not queryable and should be
      preserved when modifying objects. More info:
      https://kubernetes.io/docs/user-guide/annotations
    LabelsValue: Optional. The labels on the resource, which can be used for
      categorization. similar to Kubernetes resource labels.

  Fields:
    annotations: Optional. Annotations is an unstructured key-value map stored
      with a resource that may be set by external tools to store and retrieve
      arbitrary metadata. They are not queryable and should be preserved when
      modifying objects. More info: https://kubernetes.io/docs/user-
      guide/annotations
    createTime: Output only. The timestamp when the resource was created.
    etag: Output only. An opaque value that uniquely identifies a version or
      generation of a resource. It can be used to confirm that the client and
      server agree on the ordering of a resource being written.
    flagRevisions: Optional. Immutable. FlagRevisions to be rolled out. This
      is the ultimate source of truth of what a Rollout or a UnitOperation
      carries.
    labels: Optional. The labels on the resource, which can be used for
      categorization. similar to Kubernetes resource labels.
    name: Identifier. The resource name (full URI of the resource) following
      the standard naming scheme:
      "projects/{project}/locations/{location}/flagReleases/{flag_release_id}"
    obsoleteFlags: Optional. Immutable. Flags to be removed from given
      UnitKind and all related Units. If Flag is provided here, its
      FlagRevisions will be removed from UnitKind and Units.
    uid: Output only. The unique identifier of the resource. UID is unique in
      the time and space for this resource within the scope of the service. It
      is typically generated by the server on successful creation of a
      resource and must not be changed. UID is used to uniquely identify
      resources with resource name reuses. This should be a UUID4.
    unitKind: Required. Immutable. The UnitKind this FlagRelease applies to.
    updateTime: Output only. The timestamp when the resource was last updated.
      Any change to the resource made by users must refresh this value.
      Changes to a resource made by the service should refresh this value.
  rA   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)FlagRelease.AnnotationsValuerD   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)/FlagRelease.AnnotationsValue.AdditionalPropertyrG   r
   r   NrH   r   r   r   rK   rs   .  rL   r   rK   r
   Tr1   NrM   r   r   r   rO   rq     rP   r   rO   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)FlagRelease.LabelsValuerS   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)*FlagRelease.LabelsValue.AdditionalPropertyrV   r
   r   NrH   r   r   r   rK   rw   G  rL   r   rK   r
   Tr1   NrM   r   r   r   rW   ru   ;  rX   r   rW   r
   r   r   r:   Tr1   rY   rZ   r[   r\   r]   r^   N)r   r   r   r   r   rb   r   rN   rO   rW   r4   rc   r   rd   rf   flagRevisionsrh   ri   obsoleteFlagsrj   r%   rk   r   r   r   ro   ro      s+   )V "8!!"89Z** Z :Z6 "8!!"89ZI%% Z :Z0 '	&&'91=+$y$$Q'*			q	!$')''D9-!9!!-3&			q	!$')''D9-	a #"Y""1%($y$$R(*r   ro   c                   (   e Zd ZdZ ej
                  d       G d dej                               Z ej
                  d       G d dej                               Z	 ej                  dd      Z ej                  d      Z ej                  d	      Z ej                  d
d      Z ej                  d      Z ej                  dd      Z ej                  d      Z ej                  dd      Z ej                  d      Z ej                  d      Zy)FlagRevisiona(	  A snapshot of the EvaluationSpec for the Flag.

  Messages:
    AnnotationsValue: Optional. Annotations is an unstructured key-value map
      stored with a resource that may be set by external tools to store and
      retrieve arbitrary metadata. They are not queryable and should be
      preserved when modifying objects. More info:
      https://kubernetes.io/docs/user-guide/annotations
    LabelsValue: Optional. The labels on the resource, which can be used for
      categorization. similar to Kubernetes resource labels.

  Fields:
    annotations: Optional. Annotations is an unstructured key-value map stored
      with a resource that may be set by external tools to store and retrieve
      arbitrary metadata. They are not queryable and should be preserved when
      modifying objects. More info: https://kubernetes.io/docs/user-
      guide/annotations
    createTime: Output only. The timestamp when the resource was created.
    etag: Output only. An opaque value that uniquely identifies a version or
      generation of a resource. It can be used to confirm that the client and
      server agree on the ordering of a resource being written.
    evaluationSpec: Output only. Immutable. Snapshot of the EvaluationSpec for
      the flag. DEPRECATED: Use snapshot instead.
    flag: Required. Immutable. Name of the Flag this is a revision of.
    labels: Optional. The labels on the resource, which can be used for
      categorization. similar to Kubernetes resource labels.
    name: Identifier. The resource name (full URI of the resource) following
      the standard naming scheme: "projects/{project}/locations/{location}/fla
      gRevisions/{flag_revision_id}"
    snapshot: Output only. Immutable. Snapshot of the Flag.
    uid: Output only. The unique identifier of the resource. UID is unique in
      the time and space for this resource within the scope of the service. It
      is typically generated by the server on successful creation of a
      resource and must not be changed. UID is used to uniquely identify
      resources with resource name reuses. This should be a UUID4.
    updateTime: Output only. The timestamp when the resource was last updated.
      Any change to the resource made by users must refresh this value.
      Changes to a resource made by the service should refresh this value.
  rA   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)FlagRevision.AnnotationsValuerD   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)0FlagRevision.AnnotationsValue.AdditionalPropertyrG   r
   r   NrH   r   r   r   rK   r     rL   r   rK   r
   Tr1   NrM   r   r   r   rO   r}     rP   r   rO   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)FlagRevision.LabelsValuerS   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)+FlagRevision.LabelsValue.AdditionalPropertyrV   r
   r   NrH   r   r   r   rK   r     rL   r   rK   r
   Tr1   NrM   r   r   r   rW   r     rX   r   rW   r
   r   r   r0   r:   rY   rZ   r[   r7   r\   r]   r^   N)r   r   r   r   r   rb   r   rN   rO   rW   r4   rc   r   rd   rf   rg   flagrh   ri   snapshotrj   rk   r   r   r   r{   r{   `  s,   &P "8!!"89Z** Z :Z6 "8!!"89ZI%% Z :Z0 '	&&'91=+$y$$Q'*			q	!$)9))*:A>.			q	!$!9!!-3&			q	!$#Y##FA.(	a #$y$$R(*r   r{   c                   4    e Zd ZdZ ej
                  d      Zy)
FlagUpdatezFlagUpdate is a UnitOperation that pushes new flag values to Units.

  Fields:
    flagRelease: Required. Flag release being applied by UnitOperation.
  r
   N)r   r   r   r   r   r   flagReleaser   r   r   r   r     s     &	%%a(+r   r   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)FromMappingzOutput variables whose values will be passed on to dependencies

  Fields:
    dependency: Required. Alias of the dependency that the outputVariable will
      pass its value to
    outputVariable: Required. Name of the outputVariable on the dependency
  r
   r   N)r   r   r   r   r   r   
dependencyoutputVariabler   r   r   r   r     s-     %y$$Q'*(9((+.r   r   c                   p   e Zd ZdZ ej
                  d       G d dej                               Z ej
                  d       G d dej                               Z	 ej                  d      Z ej                  dd      Z ej                  d	      Z ej                  dd
      Z ej                  d      Zy)GoogleCloudLocationLocationao  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"`
  rA   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)'GoogleCloudLocationLocation.LabelsValuea  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                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy):GoogleCloudLocationLocation.LabelsValue.AdditionalPropertyrV   r
   r   NrH   r   r   r   rK   r     rL   r   rK   r
   Tr1   NrM   r   r   r   rW   r     rX   r   rW   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy))GoogleCloudLocationLocation.MetadataValuea(  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                   Z    e Zd ZdZ ej
                  d      Z ej                  dd      Zy)<GoogleCloudLocationLocation.MetadataValue.AdditionalPropertyzAn additional property for a MetadataValue object.

      Fields:
        key: Name of the additional property.
        value: A extra_types.JsonValue attribute.
      r
   zextra_types.JsonValuer   N)	r   r   r   r   r   r   rI   r4   rJ   r   r   r   rK   r     s0    
 "I!!!$c$i$$%<a@er   rK   r
   Tr1   NrM   r   r   r   MetadataValuer     s6    		AY.. 	A 29112FTXYr   r   r
   r   r   r:   rY   N)r   r   r   r   r   rb   r   rN   rW   r   r   displayNamer4   rh   
locationIdmetadatari   r   r   r   r   r     s    * "8!!"89ZI%% Z :Z0 "8!!"89Zi'' Z :Z2 &	%%a(+!9!!-3&$y$$Q'*#Y##OQ7(			q	!$r   r   c                       e Zd ZdZ ej
                  ddd      Z ej                  d      Z ej                  dd      Z	y)	ListFlagReleasesResponseaY  The response structure for the ListFlagReleases method.

  Fields:
    flagReleases: The resulting flag releases.
    nextPageToken: If present, the next page token can be provided to a
      subsequent ListFlagReleases call to list the next page. If empty, there
      are no more pages.
    unreachable: Locations that could not be reached.
  ro   r
   Tr1   r   r   N)
r   r   r   r   r   r4   flagReleasesr   nextPageTokenunreachabler   r   r   r   r   1  sE     (''q4H,')''*-%	%%a$7+r   r   c                       e Zd ZdZ ej
                  ddd      Z ej                  d      Z ej                  dd      Z	y)	ListFlagRevisionsResponsea]  The response structure for the ListFlagRevisions method.

  Fields:
    flagRevisions: The resulting flag revisions.
    nextPageToken: If present, the next page token can be provided to a
      subsequent ListFlagRevisions call to list the next page. If empty, there
      are no more pages.
    unreachable: Locations that could not be reached.
  r{   r
   Tr1   r   r   N)
r   r   r   r   r   r4   rx   r   r   r   r   r   r   r   r   A  sE     ))((TJ-')''*-%	%%a$7+r   r   c                       e Zd ZdZ ej
                  ddd      Z ej                  d      Z ej                  dd      Z	y)	ListFlagsResponsea<  The response structure for the ListFlags method.

  Fields:
    flags: The resulting flags.
    nextPageToken: If present, the next page token can be provided to a
      subsequent ListFlags call to list the next page. If empty, there are no
      more pages.
    unreachable: Locations that could not be reached.
  r7   r
   Tr1   r   r   N)
r   r   r   r   r   r4   flagsr   r   r   r   r   r   r   r   Q  sE     !)
 
 T
:%')''*-%	%%a$7+r   r   c                   ^    e Zd ZdZ ej
                  ddd      Z ej                  d      Zy)ListLocationsResponsezThe 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.
  r   r
   Tr1   r   N)	r   r   r   r   r   r4   	locationsr   r   r   r   r   r   r   a  s3     %i$$%BAPTU)')''*-r   r   c                       e Zd ZdZ ej
                  d      Z ej                  ddd      Z ej
                  dd      Z	y)	ListReleasesResponseaH  The response structure for the ListReleases method.

  Fields:
    nextPageToken: If present, the next page token can be provided to a
      subsequent ListReleases call to list the next page. If empty, there are
      no more pages.
    releases: The resulting releases.
    unreachable: Locations that could not be reached.
  r
   Releaser   Tr1   r   N)
r   r   r   r   r   r   r   r4   releasesr   r   r   r   r   r   n  E     ()''*-#Y##Iq4@(%	%%a$7+r   r   c                       e Zd ZdZ ej
                  d      Z ej                  ddd      Z ej
                  dd      Z	y)	ListRolloutKindsResponseaY  The response structure for the ListRolloutKinds method.

  Fields:
    nextPageToken: If present, the next page token can be provided to a
      subsequent ListRolloutKinds call to list the next page. If empty, there
      are no more pages.
    rolloutKinds: The resulting rollout kinds.
    unreachable: Locations that could not be reached.
  r
   RolloutKindr   Tr1   r   N)
r   r   r   r   r   r   r   r4   rolloutKindsr   r   r   r   r   r   ~  sE     ()''*-'''q4H,%	%%a$7+r   r   c                       e Zd ZdZ ej
                  d      Z ej                  ddd      Z ej
                  dd      Z	y)	ListRolloutsResponseaH  The response structure for the ListRollouts method.

  Fields:
    nextPageToken: If present, the next page token can be provided to a
      subsequent ListRollouts call to list the next page. If empty, there are
      no more pages.
    rollouts: The resulting rollouts.
    unreachable: Locations that could not be reached.
  r
   Rolloutr   Tr1   r   N)
r   r   r   r   r   r   r   r4   rolloutsr   r   r   r   r   r     r   r   r   c                       e Zd ZdZ ej
                  d      Z ej                  ddd      Z ej
                  dd      Z	y)	ListSaasResponsea8  The response structure for the ListSaas method.

  Fields:
    nextPageToken: If present, the next page token can be provided to a
      subsequent ListSaas call to list the next page. If empty, there are no
      more pages.
    saas: The resulting saas.
    unreachable: Locations that could not be reached.
  r
   Saasr   Tr1   r   N)
r   r   r   r   r   r   r   r4   saasr   r   r   r   r   r     sE     ()''*-			D	9$%	%%a$7+r   r   c                       e Zd ZdZ ej
                  d      Z ej                  ddd      Z ej
                  dd      Z	y)	ListTenantsResponseaD  The response structure for the ListTenants method.

  Fields:
    nextPageToken: If present, the next page token can be provided to a
      subsequent ListTenants call to list the next page. If empty, there are
      no more pages.
    tenants: The resulting tenants.
    unreachable: Locations that could not be reached.
  r
   Tenantr   Tr1   r   N)
r   r   r   r   r   r   r   r4   tenantsr   r   r   r   r   r     sE     ()''*-"I""8Q>'%	%%a$7+r   r   c                       e Zd ZdZ ej
                  d      Z ej                  ddd      Z ej
                  dd      Z	y)	ListUnitKindsResponseaM  The response structure for the ListUnitKinds method.

  Fields:
    nextPageToken: If present, the next page token can be provided to a
      subsequent ListUnitKinds call to list the next page. If empty, there are
      no more pages.
    unitKinds: The resulting unit kinds.
    unreachable: Locations that could not be reached.
  r
   UnitKindr   Tr1   r   N)
r   r   r   r   r   r   r   r4   	unitKindsr   r   r   r   r   r     sE     ()''*-$i$$ZTB)%	%%a$7+r   r   c                       e Zd ZdZ ej
                  d      Z ej                  ddd      Z ej
                  dd      Z	y)	ListUnitOperationsResponseaa  The response structure for the ListUnitOperations method.

  Fields:
    nextPageToken: If present, the next page token can be provided to a
      subsequent ListUnitOperations call to list the next page. If empty,
      there are no more pages.
    unitOperations: The resulting unit operations.
    unreachable: Locations that could not be reached.
  r
   UnitOperationr   Tr1   r   N)
r   r   r   r   r   r   r   r4   unitOperationsr   r   r   r   r   r     sE     ()''*-)9))/1tL.%	%%a$7+r   r   c                       e Zd ZdZ ej
                  d      Z ej                  ddd      Z ej
                  dd      Z	y)	ListUnitsResponsea<  The response structure for the ListUnits method.

  Fields:
    nextPageToken: If present, the next page token can be provided to a
      subsequent ListUnits call to list the next page. If empty, there are no
      more pages.
    units: The resulting units.
    unreachable: Locations that could not be reached.
  r
   Unitr   Tr1   r   N)
r   r   r   r   r   r   r   r4   unitsr   r   r   r   r   r     sE     ()''*-
 )
 
 T
:%%	%%a$7+r   r   c                   4    e Zd ZdZ ej
                  d      Zy)LocationzjLocation information that the service is available in.

  Fields:
    name: Optional. Name of location.
  r
   Nr   r   r   r   r   r   ri   r   r   r   r   r     s     
		q	!$r   r   c                   4    e Zd ZdZ ej
                  d      Zy)MaintenanceSettingsa  Captures requested directives for performing future maintenance on the
  unit. This includes a request for the unit to skip maintenance for a period
  of time and remain pinned to its current release as well as controls for
  postponing maintenance scheduled in future.

  Fields:
    pinnedUntilTime: Optional. If present, it fixes the release on the unit
      until the given time; i.e. changes to the release field will be
      rejected. Rollouts should and will also respect this by not requesting
      an upgrade in the first place.
  r
   N)r   r   r   r   r   r   pinnedUntilTimer   r   r   r   r     s    
 *I))!,/r   r   c                   ^    e Zd ZdZ ej
                  ddd      Z ej                  d      Zy)	ProvisionaW  Provision is the unit operation that provision the underlying resources
  represented by a Unit. Can only execute if the Unit is not currently
  provisioned.

  Fields:
    inputVariables: Optional. Set of input variables. Maximum 100. (optional)
    release: Optional. Reference to the Release object to use for the Unit.
      (optional).
  UnitVariabler
   Tr1   r   N	r   r   r   r   r   r4   inputVariablesr   releaser   r   r   r   r     1     *9)).!dK.!I!!!$'r   r   c                      e Zd ZdZ ej
                  d       G d dej                               Z ej
                  d       G d dej                               Z	 ej                  dd      Z ej                  dd	      Z ej                  d
      Z ej                  d      Z ej                  ddd      Z ej                  ddd      Z ej                  dd      Z ej                  d      Z ej                  ddd      Z ej                  dd      Z ej                  d      Z ej                  d      Z ej                  d      Zy)r   a  A new version to be propagated and deployed to units. This includes
  pointers to packaged blueprints for actuation (e.g Helm or Terraform
  configuration packages) via artifact registry.

  Messages:
    AnnotationsValue: Optional. Annotations is an unstructured key-value map
      stored with a resource that may be set by external tools to store and
      retrieve arbitrary metadata. They are not queryable and should be
      preserved when modifying objects. More info:
      https://kubernetes.io/docs/user-guide/annotations
    LabelsValue: Optional. The labels on the resource, which can be used for
      categorization. similar to Kubernetes resource labels.

  Fields:
    annotations: Optional. Annotations is an unstructured key-value map stored
      with a resource that may be set by external tools to store and retrieve
      arbitrary metadata. They are not queryable and should be preserved when
      modifying objects. More info: https://kubernetes.io/docs/user-
      guide/annotations
    blueprint: Optional. Blueprints are OCI Images that contain all of the
      artifacts needed to provision a unit.
    createTime: Output only. The timestamp when the resource was created.
    etag: Output only. An opaque value that uniquely identifies a version or
      generation of a resource. It can be used to confirm that the client and
      server agree on the ordering of a resource being written.
    inputVariableDefaults: Optional. Mapping of input variables to default
      values. Maximum 100
    inputVariables: Optional. Output only. List of input variables declared on
      the blueprint and can be present with their values on the unit spec
    labels: Optional. The labels on the resource, which can be used for
      categorization. similar to Kubernetes resource labels.
    name: Identifier. The resource name (full URI of the resource) following
      the standard naming scheme:
      "projects/{project}/locations/{location}/releases/{release}"
    outputVariables: Optional. Output only. List of output variables declared
      on the blueprint and can be present with their values on the unit status
    releaseRequirements: Optional. Set of requirements to be fulfilled on the
      Unit when using this Release.
    uid: Output only. The unique identifier of the resource. UID is unique in
      the time and space for this resource within the scope of the service. It
      is typically generated by the server on successful creation of a
      resource and must not be changed. UID is used to uniquely identify
      resources with resource name reuses. This should be a UUID4.
    unitKind: Required. Immutable. Reference to the UnitKind this Release
      corresponds to (required and immutable once created).
    updateTime: Output only. The timestamp when the resource was last updated.
      Any change to the resource made by users must refresh this value.
      Changes to a resource made by the service should refresh this value.
  rA   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)Release.AnnotationsValuerD   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)+Release.AnnotationsValue.AdditionalPropertyrG   r
   r   NrH   r   r   r   rK   r   Y  rL   r   rK   r
   Tr1   NrM   r   r   r   rO   r   J  rP   r   rO   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)Release.LabelsValuerS   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)&Release.LabelsValue.AdditionalPropertyrV   r
   r   NrH   r   r   r   rK   r   r  rL   r   rK   r
   Tr1   NrM   r   r   r   rW   r   f  rX   r   rW   r
   r   r   r   r:   r   rY   Tr1   rZ   r[   r\   r]   ReleaseRequirementsr^   r_   r`      N)r   r   r   r   r   rb   r   rN   rO   rW   r4   rc   	blueprintr   rd   rf   inputVariableDefaultsr   rh   ri   outputVariablesreleaseRequirementsrj   r%   rk   r   r   r   r   r     sp   0d "8!!"89Z** Z :Z6 "8!!"89ZI%% Z :Z0 '	&&'91=+$i$$[!4)$y$$Q'*			q	!$0)00TR)9)).!dK.!9!!-3&			q	!$*I**>1tL/.	../DbI	b!#"Y""2&($y$$R(*r   r   c                   8    e Zd ZdZ ej
                  dd      Zy)r   ag  Set of requirements to be fulfilled on the Unit when using this Release.

  Fields:
    upgradeableFromReleases: Optional. A list of releases from which a unit
      can be upgraded to this one (optional). If left empty no constraints
      will be applied. When provided, unit upgrade requests to this release
      will check and enforce this constraint.
  r
   Tr1   N)r   r   r   r   r   r   upgradeableFromReleasesr   r   r   r   r     s     2I11!dCr   r   c                      e Zd ZdZ G d dej
                        Z ej                  d       G d dej                               Z
 ej                  d       G d dej                               Z ej                  dd	      Z ej                  d
d      Z ej                  d      Z ej                  d      Z ej                  d      Z ej                  d      Z ej                  dd      Z ej                  d      Z ej                  d      Z ej                  d      Z ej                  d      Z ej                  d      Z ej                  d      Z ej                  d      Z ej8                  dd      Z ej                  d      Z ej                  d      Z ej                  dd      Z  ej                  d      Z! ej                  d      Z" ej                  d      Z#y )!r   a  Represents a single rollout execution and its results

  Enums:
    StateValueValuesEnum: Output only. Current state of the rollout.

  Messages:
    AnnotationsValue: Optional. Annotations is an unstructured key-value map
      stored with a resource that may be set by external tools to store and
      retrieve arbitrary metadata. They are not queryable and should be
      preserved when modifying objects. More info:
      https://kubernetes.io/docs/user-guide/annotations
    LabelsValue: Optional. The labels on the resource, which can be used for
      categorization. similar to Kubernetes resource labels.

  Fields:
    annotations: Optional. Annotations is an unstructured key-value map stored
      with a resource that may be set by external tools to store and retrieve
      arbitrary metadata. They are not queryable and should be preserved when
      modifying objects. More info: https://kubernetes.io/docs/user-
      guide/annotations
    control: Optional. Requested change to the execution of this rollout.
      Default RolloutControl.action is ROLLOUT_ACTION_RUN meaning the rollout
      will be executed to completion while progressing through all natural
      Rollout States (such as RUNNING -> SUCCEEDED or RUNNING -> FAILED).
      Requests can only be made when the Rollout is in a non-terminal state.
    createTime: Output only. The timestamp when the resource was created.
    endTime: Optional. Output only. The time when the rollout finished
      execution (regardless of success, failure, or cancellation). Will be
      empty if the rollout hasn't finished yet. Once set, the rollout is in
      terminal state and all the results are final.
    etag: Output only. An opaque value that uniquely identifies a version or
      generation of a resource. It can be used to confirm that the client and
      server agree on the ordering of a resource being written.
    flagRelease: Optional. Immutable. Name of the FlagRelease to be rolled out
      to the target Units. Release and FlagRelease are mutually exclusive.
      Note: `release` comment needs to be adjusted to mention that "Release
      and FlagRelease are mutually exclusive" when visibility restriction will
      be lifted.
    labels: Optional. The labels on the resource, which can be used for
      categorization. similar to Kubernetes resource labels.
    name: Identifier. The resource name (full URI of the resource) following
      the standard naming scheme:
      "projects/{project}/locations/{location}/rollout/{rollout_id}"
    parentRollout: Optional. Output only. The direct parent rollout that this
      rollout is stemming from. The resource name (full URI of the resource)
      following the standard naming scheme:
      "projects/{project}/locations/{location}/rollouts/{rollout_id}"
    release: Optional. Immutable. Name of the Release that gets rolled out to
      target Units. Required if no other type of release is specified.
    rolloutKind: Optional. Immutable. Name of the RolloutKind this rollout is
      stemming from and adhering to.
    rolloutOrchestrationStrategy: Optional. The strategy used for executing
      this Rollout. This strategy will override whatever strategy is specified
      in the RolloutKind. If not specified on creation, the strategy from
      RolloutKind will be used. There are two supported values strategies
      which are used to control - "Google.Cloud.Simple.AllAtOnce" -
      "Google.Cloud.Simple.OneLocationAtATime" A rollout with one of these
      simple strategies will rollout across all locations defined in the
      targeted UnitKind's Saas Locations.
    rootRollout: Optional. Output only. The root rollout that this rollout is
      stemming from. The resource name (full URI of the resource) following
      the standard naming scheme:
      "projects/{project}/locations/{location}/rollouts/{rollout_id}"
    startTime: Optional. Output only. The time when the rollout started
      executing. Will be empty if the rollout hasn't started yet.
    state: Output only. Current state of the rollout.
    stateMessage: Output only. Human readable message indicating details about
      the last state transition.
    stateTransitionTime: Optional. Output only. The time when the rollout
      transitioned into its current state.
    stats: Optional. Output only. Details about the progress of the rollout.
    uid: Output only. The unique identifier of the resource. UID is unique in
      the time and space for this resource within the scope of the service. It
      is typically generated by the server on successful creation of a
      resource and must not be changed. UID is used to uniquely identify
      resources with resource name reuses. This should be a UUID4.
    unitFilter: Optional. CEL(https://github.com/google/cel-spec) formatted
      filter string against Unit. The filter will be applied to determine the
      eligible unit population. This filter can only reduce, but not expand
      the scope of the rollout. If not provided, the unit_filter from the
      RolloutKind will be used.
    updateTime: Output only. The timestamp when the resource was last updated.
      Any change to the resource made by users must refresh this value.
      Changes to a resource made by the service should refresh this value.
  c                   8    e Zd ZdZdZdZdZdZdZdZ	dZ
d	Zd
ZdZy)Rollout.StateValueValuesEnuma  Output only. Current state of the rollout.

    Values:
      ROLLOUT_STATE_UNSPECIFIED: Unspecified state.
      ROLLOUT_STATE_RUNNING: Rollout is in progress.
      ROLLOUT_STATE_PAUSED: Rollout has been paused.
      ROLLOUT_STATE_SUCCEEDED: Rollout completed successfully.
      ROLLOUT_STATE_FAILED: Rollout has failed.
      ROLLOUT_STATE_CANCELLED: Rollout has been canceled.
      ROLLOUT_STATE_WAITING: Rollout is waiting for some condition to be met
        before starting.
      ROLLOUT_STATE_CANCELLING: Rollout is being canceled.
      ROLLOUT_STATE_RESUMING: Rollout is being resumed.
      ROLLOUT_STATE_PAUSING: Rollout is being paused.
    r   r
   r   r   r:   rY   rZ   r[   r\   r]   N)r   r   r   r   ROLLOUT_STATE_UNSPECIFIEDROLLOUT_STATE_RUNNINGROLLOUT_STATE_PAUSEDROLLOUT_STATE_SUCCEEDEDROLLOUT_STATE_FAILEDROLLOUT_STATE_CANCELLEDROLLOUT_STATE_WAITINGROLLOUT_STATE_CANCELLINGROLLOUT_STATE_RESUMINGROLLOUT_STATE_PAUSINGr   r   r   StateValueValuesEnumr     sE     !" r   r   rA   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)Rollout.AnnotationsValuerD   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)+Rollout.AnnotationsValue.AdditionalPropertyrG   r
   r   NrH   r   r   r   rK   r     rL   r   rK   r
   Tr1   NrM   r   r   r   rO   r     rP   r   rO   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)Rollout.LabelsValuerS   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)&Rollout.LabelsValue.AdditionalPropertyrV   r
   r   NrH   r   r   r   rK   r   5  rL   r   rK   r
   Tr1   NrM   r   r   r   rW   r   )  rX   r   rW   r
   RolloutControlr   r   r:   rY   rZ   r[   r\   r]   r^   r_   r`   r               RolloutStats            N)$r   r   r   r   r   ra   r   r   rb   rN   rO   rW   r4   rc   controlr   rd   endTimerf   r   rh   ri   parentRolloutr   rolloutKindrolloutOrchestrationStrategyrootRollout	startTimerl   statestateMessagestateTransitionTimestatsrj   
unitFilterrk   r   r   r   r   r     s   TlY^^ 6 "8!!"89Z** Z :Z6 "8!!"89ZI%% Z :Z0 '	&&'91=+"I""#3Q7'$y$$Q'*!I!!!$'			q	!$%	%%a(+!9!!-3&			q	!$')''*-!I!!"%'%	%%b)+!6!6!6r!:%	%%b)+#i##B')
)

4b
9%&&&r*,-	--b1
 )
 
 
4%	b!#$y$$R(*$y$$R(*r   r   c                       e Zd ZdZ G d dej
                        Z ej                  dd      Z ej                  dd      Z
y)r   a  RolloutControl provides a way to request a change to the execution of a
  Rollout by pausing or canceling it.

  Enums:
    ActionValueValuesEnum: Required. Action to be performed on the Rollout.
      The default behavior is to run the rollout until it naturally reaches a
      terminal state.

  Fields:
    action: Required. Action to be performed on the Rollout. The default
      behavior is to run the rollout until it naturally reaches a terminal
      state.
    runParams: Optional. Parameters for the RUN action. It is an error to
      specify this if the RolloutAction is not set to RUN. By default, the
      rollout will retry failed operations when resumed.
  c                        e Zd ZdZdZdZdZdZy)$RolloutControl.ActionValueValuesEnuma/  Required. Action to be performed on the Rollout. The default behavior
    is to run the rollout until it naturally reaches a terminal state.

    Values:
      ROLLOUT_ACTION_UNSPECIFIED: Unspecified action, will be treated as RUN
        by default.
      ROLLOUT_ACTION_RUN: Run the Rollout until it naturally reaches a
        terminal state. A rollout requested to run will progress through all
        natural Rollout States (such as RUNNING -> SUCCEEDED or RUNNING ->
        FAILED). If retriable errors are encountered during the rollout, the
        rollout will paused by default and can be resumed by re-requesting
        this RUN action.
      ROLLOUT_ACTION_PAUSE: Pause the Rollout until it is resumed (i.e. RUN is
        requested).
      ROLLOUT_ACTION_CANCEL: Cancel the Rollout permanently.
    r   r
   r   r   N)r   r   r   r   ROLLOUT_ACTION_UNSPECIFIEDROLLOUT_ACTION_RUNROLLOUT_ACTION_PAUSEROLLOUT_ACTION_CANCELr   r   r   ActionValueValuesEnumr  k  s!      "#r   r  r
   RunRolloutActionParamsr   N)r   r   r   r   r   ra   r  rl   actionr4   	runParamsr   r   r   r   r   Y  sC    "inn , 96:&$i$$%=qA)r   r   c                      e Zd ZdZ G d dej
                        Z ej                  d       G d dej                               Z
 ej                  d       G d dej                               Z ej                  dd	      Z ej                  d
      Z ej                  dd      Z ej                  d      Z ej                  dd      Z ej                  d      Z ej                  d      Z ej                  d      Z ej                  d      Z ej                  d      Z ej                  d      Z ej2                  dd      Zy)r   a  An object that describes various settings of Rollout execution. Includes
  built-in policies across GCP and GDC, and customizable policies.

  Enums:
    UpdateUnitKindStrategyValueValuesEnum: Optional. The config for updating
      the unit kind. By default, the unit kind will be updated on the rollout
      start.

  Messages:
    AnnotationsValue: Optional. Annotations is an unstructured key-value map
      stored with a resource that may be set by external tools to store and
      retrieve arbitrary metadata. They are not queryable and should be
      preserved when modifying objects. More info:
      https://kubernetes.io/docs/user-guide/annotations
    LabelsValue: Optional. The labels on the resource, which can be used for
      categorization. similar to Kubernetes resource labels.

  Fields:
    annotations: Optional. Annotations is an unstructured key-value map stored
      with a resource that may be set by external tools to store and retrieve
      arbitrary metadata. They are not queryable and should be preserved when
      modifying objects. More info: https://kubernetes.io/docs/user-
      guide/annotations
    createTime: Output only. The timestamp when the resource was created.
    errorBudget: Optional. The configuration for error budget. If the number
      of failed units exceeds max(allowed_count, allowed_ratio * total_units),
      the rollout will be paused. If not set, all units will be attempted to
      be updated regardless of the number of failures encountered.
    etag: Output only. An opaque value that uniquely identifies a version or
      generation of a resource. It can be used to confirm that the client and
      server agree on the ordering of a resource being written.
    labels: Optional. The labels on the resource, which can be used for
      categorization. similar to Kubernetes resource labels.
    name: Identifier. The resource name (full URI of the resource) following
      the standard naming scheme:
      "projects/{project}/locations/{location}/rolloutKinds/{rollout_kind_id}"
    rolloutOrchestrationStrategy: Optional. The strategy used for executing a
      Rollout. This is a required field. There are two supported values
      strategies which are used to control - "Google.Cloud.Simple.AllAtOnce" -
      "Google.Cloud.Simple.OneLocationAtATime" A rollout with one of these
      simple strategies will rollout across all locations defined in the
      associated UnitKind's Saas Locations.
    uid: Output only. The unique identifier of the resource. UID is unique in
      the time and space for this resource within the scope of the service. It
      is typically generated by the server on successful creation of a
      resource and must not be changed. UID is used to uniquely identify
      resources with resource name reuses. This should be a UUID4.
    unitFilter: Optional. CEL(https://github.com/google/cel-spec) formatted
      filter string against Unit. The filter will be applied to determine the
      eligible unit population. This filter can only reduce, but not expand
      the scope of the rollout.
    unitKind: Required. Immutable. UnitKind that this rollout kind corresponds
      to. Rollouts stemming from this rollout kind will target the units of
      this unit kind. In other words, this defines the population of target
      units to be upgraded by rollouts.
    updateTime: Output only. The timestamp when the resource was last updated.
      Any change to the resource made by users must refresh this value.
      Changes to a resource made by the service should refresh this value.
    updateUnitKindStrategy: Optional. The config for updating the unit kind.
      By default, the unit kind will be updated on the rollout start.
  c                       e Zd ZdZdZdZdZy)1RolloutKind.UpdateUnitKindStrategyValueValuesEnumar  Optional. The config for updating the unit kind. By default, the unit
    kind will be updated on the rollout start.

    Values:
      UPDATE_UNIT_KIND_STRATEGY_UNSPECIFIED: Strategy unspecified.
      UPDATE_UNIT_KIND_STRATEGY_ON_START: Update the unit kind strategy on the
        rollout start.
      UPDATE_UNIT_KIND_STRATEGY_NEVER: Never update the unit kind.
    r   r
   r   N)r   r   r   r   %UPDATE_UNIT_KIND_STRATEGY_UNSPECIFIED"UPDATE_UNIT_KIND_STRATEGY_ON_STARTUPDATE_UNIT_KIND_STRATEGY_NEVERr   r   r   %UpdateUnitKindStrategyValueValuesEnumr     s     -.))*&&'#r   r$  rA   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)RolloutKind.AnnotationsValuerD   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)/RolloutKind.AnnotationsValue.AdditionalPropertyrG   r
   r   NrH   r   r   r   rK   r(    rL   r   rK   r
   Tr1   NrM   r   r   r   rO   r&    rP   r   rO   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)RolloutKind.LabelsValuerS   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)*RolloutKind.LabelsValue.AdditionalPropertyrV   r
   r   NrH   r   r   r   rK   r,    rL   r   rK   r
   Tr1   NrM   r   r   r   rW   r*    rX   r   rW   r
   r   r,   r   r:   rY   rZ   r[   r\   r]   r^   r_   r`   N)r   r   r   r   r   ra   r$  r   rb   rN   rO   rW   r4   rc   r   rd   errorBudgetrf   rh   ri   r  rj   r  r%   rk   rl   updateUnitKindStrategyr   r   r   r   r     sc   <|(inn ( "8!!"89Z** Z :Z6 "8!!"89ZI%% Z :Z0 '	&&'91=+$y$$Q'*&	&&}a8+			q	!$!9!!-3&			q	!$!6!6!6q!9	a #$y$$Q'*"Y""2&($y$$R(*.9../VXZ[r   r   c                   :    e Zd ZdZ ej
                  ddd      Zy)r  a  RolloutStats contains information about the progress of a rollout.

  Fields:
    operationsByState: Output only. A breakdown of the progress of operations
      triggered by the rollout. Provides a count of Operations by their state.
      This can be used to determine the number of units which have been
      updated, or are scheduled to be updated. There will be at most one entry
      per group. Possible values for operation groups are: - "SCHEDULED" -
      "PENDING" - "RUNNING" - "SUCCEEDED" - "FAILED" - "CANCELLED"
  r	   r
   Tr1   N)r   r   r   r   r   r4   operationsByStater   r   r   r  r    s     	 -i,,[!dKr   r  c                   4    e Zd ZdZ ej
                  d      Zy)r  aR  Parameters for the RUN action controlling the behavior of the rollout
  when it is resumed from a PAUSED state.

  Fields:
    retryFailedOperations: Required. If true, the rollout will retry failed
      operations when resumed. This is applicable only the current state of
      the Rollout is PAUSED and the requested action is RUN.
  r
   N)r   r   r   r   r   BooleanFieldretryFailedOperationsr   r   r   r  r  $  s     1)003r   r  c                      e Zd ZdZ ej
                  d       G d dej                               Z ej
                  d       G d dej                               Z	 ej                  dd      Z ej                  d      Z ej                  d	      Z ej                  dd
      Z ej                  ddd      Z ej                  d      Z ej                  d      Z ej                  d      Zy)r   a  Saas is a representation of a SaaS service managed by the Producer.

  Messages:
    AnnotationsValue: Optional. Annotations is an unstructured key-value map
      stored with a resource that may be set by external tools to store and
      retrieve arbitrary metadata. They are not queryable and should be
      preserved when modifying objects. More info:
      https://kubernetes.io/docs/user-guide/annotations
    LabelsValue: Optional. The labels on the resource, which can be used for
      categorization. similar to Kubernetes resource labels.

  Fields:
    annotations: Optional. Annotations is an unstructured key-value map stored
      with a resource that may be set by external tools to store and retrieve
      arbitrary metadata. They are not queryable and should be preserved when
      modifying objects. More info: https://kubernetes.io/docs/user-
      guide/annotations
    createTime: Output only. The timestamp when the resource was created.
    etag: Output only. An opaque value that uniquely identifies a version or
      generation of a resource. It can be used to confirm that the client and
      server agree on the ordering of a resource being written.
    labels: Optional. The labels on the resource, which can be used for
      categorization. similar to Kubernetes resource labels.
    locations: Optional. List of locations that the service is available in.
      Rollout refers to the list to generate a rollout plan.
    name: Identifier. The resource name (full URI of the resource) following
      the standard naming scheme:
      "projects/{project}/locations/{location}/saas/{saas}"
    uid: Output only. The unique identifier of the resource. UID is unique in
      the time and space for this resource within the scope of the service. It
      is typically generated by the server on successful creation of a
      resource and must not be changed. UID is used to uniquely identify
      resources with resource name reuses. This should be a UUID4.
    updateTime: Output only. The timestamp when the resource was last updated.
      Any change to the resource made by users must refresh this value.
      Changes to a resource made by the service should refresh this value.
  rA   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)Saas.AnnotationsValuerD   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)(Saas.AnnotationsValue.AdditionalPropertyrG   r
   r   NrH   r   r   r   rK   r8  g  rL   r   rK   r
   Tr1   NrM   r   r   r   rO   r6  X  rP   r   rO   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)Saas.LabelsValuerS   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)#Saas.LabelsValue.AdditionalPropertyrV   r
   r   NrH   r   r   r   rK   r<    rL   r   rK   r
   Tr1   NrM   r   r   r   rW   r:  t  rX   r   rW   r
   r   r   r:   r   rY   Tr1   rZ   r[   r\   N)r   r   r   r   r   rb   r   rN   rO   rW   r4   rc   r   rd   rf   rh   r   ri   rj   rk   r   r   r   r   r   1  s   $L "8!!"89Z** Z :Z6 "8!!"89ZI%% Z :Z0 '	&&'91=+$y$$Q'*			q	!$!9!!-3&$i$$ZTB)			q	!$	a #$y$$Q'*r   r   c                       e Zd ZdZ ej
                  dd      Z ej                  d      Z ej                  dd      Z	 ej                  d      Z
 ej                  d	      Zy
)9SaasservicemgmtProjectsLocationsFlagReleasesCreateRequesta  A SaasservicemgmtProjectsLocationsFlagReleasesCreateRequest object.

  Fields:
    flagRelease: A FlagRelease resource to be passed as the request body.
    flagReleaseId: Required. The ID value for the new flag release.
    parent: Required. The parent of the flag release.
    requestId: An optional 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 since 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).
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  ro   r
   r   r   Trequiredr:   rY   N)r   r   r   r   r   r4   r   r   flagReleaseIdparent	requestIdr2  validateOnlyr   r   r   r>  r>    sg    , '	&&}a8+')''*- 9  T2&#i##A&)'''*,r   r>  c                       e Zd ZdZ ej
                  d      Z ej
                  dd      Z ej
                  d      Z ej                  d      Z
y)	9SaasservicemgmtProjectsLocationsFlagReleasesDeleteRequestah  A SaasservicemgmtProjectsLocationsFlagReleasesDeleteRequest object.

  Fields:
    etag: The etag known to the client for the expected state of the flag
      release. This is used with state-changing methods to prevent accidental
      overwrites when multiple user agents might be acting in parallel on the
      same resource. An etag wildcard provide optimistic concurrency based on
      the expected existence of the flag release. The Any wildcard (`*`)
      requires that the resource must already exists, and the Not Any wildcard
      (`!*`) requires that it must not.
    name: Required. The resource name of the resource within a service.
    requestId: An optional 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 since 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).
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   r   Tr?  r   r:   Nr   r   r   r   r   r   rf   ri   rC  r2  rD  r   r   r   rF  rF    S    6 
		q	!$			q4	0$#i##A&)'''*,r   rF  c                   8    e Zd ZdZ ej
                  dd      Zy)6SaasservicemgmtProjectsLocationsFlagReleasesGetRequestzA SaasservicemgmtProjectsLocationsFlagReleasesGetRequest object.

  Fields:
    name: Required. The resource name of the resource within a service.
  r
   Tr?  Nr   r   r   r   rJ  rJ         
		q4	0$r   rJ  c                       e Zd ZdZ ej
                  d      Z ej
                  d      Z ej                  dej                  j                        Z ej
                  d      Z ej
                  dd	      Zy
)7SaasservicemgmtProjectsLocationsFlagReleasesListRequesta  A SaasservicemgmtProjectsLocationsFlagReleasesListRequest object.

  Fields:
    filter: Filter the list as specified in https://google.aip.dev/160.
    orderBy: Order results as specified in https://google.aip.dev/132.
    pageSize: The maximum number of flag releases to send per page.
    pageToken: The page token: If the next_page_token from a previous response
      is provided, this request will send the subsequent page.
    parent: Required. The parent of the flag release.
  r
   r   r   r   r:   rY   Tr?  Nr   r   r   r   r   r   filterorderByr   r   r   pageSize	pageTokenrB  r   r   r   rM  rM    s    	 !9  #&!I!!!$'#Y##Ay/@/@/F/FG(#i##A&) 9  T2&r   rM  c                       e Zd ZdZ ej
                  dd      Z ej                  dd      Z ej                  d      Z	 ej                  d      Z
 ej                  d	      Zy
)8SaasservicemgmtProjectsLocationsFlagReleasesPatchRequesta  A SaasservicemgmtProjectsLocationsFlagReleasesPatchRequest object.

  Fields:
    flagRelease: A FlagRelease resource to be passed as the request body.
    name: Identifier. The resource name (full URI of the resource) following
      the standard naming scheme:
      "projects/{project}/locations/{location}/flagReleases/{flag_release_id}"
    requestId: An optional 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 since 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: Field mask is used to specify the fields to be overwritten in
      the FlagRelease resource by the update. The fields specified in the
      update_mask are relative to the resource, not the full request. A field
      will be overwritten if it is in the mask. If the user does not provide a
      mask then all fields in the FlagRelease will be overwritten.
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  ro   r
   r   Tr?  r   r:   rY   N)r   r   r   r   r   r4   r   r   ri   rC  
updateMaskr2  rD  r   r   r   rU  rU    sg    8 '	&&}a8+			q4	0$#i##A&)$y$$Q'*'''*,r   rU  c                       e Zd ZdZ ej
                  dd      Z ej                  d      Z ej                  dd      Z	 ej                  d      Z
 ej                  d	      Zy
):SaasservicemgmtProjectsLocationsFlagRevisionsCreateRequesta  A SaasservicemgmtProjectsLocationsFlagRevisionsCreateRequest object.

  Fields:
    flagRevision: A FlagRevision resource to be passed as the request body.
    flagRevisionId: Required. The ID value for the new flag revision.
    parent: Required. The parent of the flag revision.
    requestId: An optional 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 since 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).
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r{   r
   r   r   Tr?  r:   rY   N)r   r   r   r   r   r4   flagRevisionr   flagRevisionIdrB  rC  r2  rD  r   r   r   rX  rX    sg    , ('':,(9((+. 9  T2&#i##A&)'''*,r   rX  c                       e Zd ZdZ ej
                  d      Z ej
                  dd      Z ej
                  d      Z ej                  d      Z
y)	:SaasservicemgmtProjectsLocationsFlagRevisionsDeleteRequestak  A SaasservicemgmtProjectsLocationsFlagRevisionsDeleteRequest object.

  Fields:
    etag: The etag known to the client for the expected state of the flag
      revision. This is used with state-changing methods to prevent accidental
      overwrites when multiple user agents might be acting in parallel on the
      same resource. An etag wildcard provide optimistic concurrency based on
      the expected existence of the flag revision. The Any wildcard (`*`)
      requires that the resource must already exists, and the Not Any wildcard
      (`!*`) requires that it must not.
    name: Required. The resource name of the resource within a service.
    requestId: An optional 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 since 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).
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   r   Tr?  r   r:   NrG  r   r   r   r\  r\  6  rH  r   r\  c                   8    e Zd ZdZ ej
                  dd      Zy)7SaasservicemgmtProjectsLocationsFlagRevisionsGetRequestzA SaasservicemgmtProjectsLocationsFlagRevisionsGetRequest object.

  Fields:
    name: Required. The resource name of the resource within a service.
  r
   Tr?  Nr   r   r   r   r^  r^  X  rK  r   r^  c                       e Zd ZdZ ej
                  d      Z ej
                  d      Z ej                  dej                  j                        Z ej
                  d      Z ej
                  dd	      Zy
)8SaasservicemgmtProjectsLocationsFlagRevisionsListRequesta  A SaasservicemgmtProjectsLocationsFlagRevisionsListRequest object.

  Fields:
    filter: Filter the list as specified in https://google.aip.dev/160.
    orderBy: Order results as specified in https://google.aip.dev/132.
    pageSize: The maximum number of flag revisions to send per page.
    pageToken: The page token: If the next_page_token from a previous response
      is provided, this request will send the subsequent page.
    parent: Required. The parent of the flag revision.
  r
   r   r   r   r:   rY   Tr?  NrN  r   r   r   r`  r`  b  rS  r   r`  c                       e Zd ZdZ ej
                  dd      Z ej                  dd      Z ej                  d      Z	 ej                  d      Z
 ej                  d	      Zy
)9SaasservicemgmtProjectsLocationsFlagRevisionsPatchRequesta  A SaasservicemgmtProjectsLocationsFlagRevisionsPatchRequest object.

  Fields:
    flagRevision: A FlagRevision resource to be passed as the request body.
    name: Identifier. The resource name (full URI of the resource) following
      the standard naming scheme: "projects/{project}/locations/{location}/fla
      gRevisions/{flag_revision_id}"
    requestId: An optional 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 since 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: Field mask is used to specify the fields to be overwritten in
      the FlagRevision resource by the update. The fields specified in the
      update_mask are relative to the resource, not the full request. A field
      will be overwritten if it is in the mask. If the user does not provide a
      mask then all fields in the FlagRevision will be overwritten.
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r{   r
   r   Tr?  r   r:   rY   N)r   r   r   r   r   r4   rY  r   ri   rC  rV  r2  rD  r   r   r   rb  rb  u  sg    8 ('':,			q4	0$#i##A&)$y$$Q'*'''*,r   rb  c                       e Zd ZdZ ej
                  dd      Z ej                  d      Z ej                  dd      Z	 ej                  d      Z
 ej                  d	      Zy
)2SaasservicemgmtProjectsLocationsFlagsCreateRequesta  A SaasservicemgmtProjectsLocationsFlagsCreateRequest object.

  Fields:
    flag: A Flag resource to be passed as the request body.
    flagId: Required. The ID value for the new flag.
    parent: Required. The parent of the flag.
    requestId: An optional 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 since 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).
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r7   r
   r   r   Tr?  r:   rY   N)r   r   r   r   r   r4   r   r   flagIdrB  rC  r2  rD  r   r   r   rd  rd    sg    , 
 			*$ 9  #& 9  T2&#i##A&)'''*,r   rd  c                       e Zd ZdZ ej
                  d      Z ej
                  dd      Z ej
                  d      Z ej                  d      Z
y)	2SaasservicemgmtProjectsLocationsFlagsDeleteRequestaQ  A SaasservicemgmtProjectsLocationsFlagsDeleteRequest object.

  Fields:
    etag: The etag known to the client for the expected state of the flag.
      This is used with state-changing methods to prevent accidental
      overwrites when multiple user agents might be acting in parallel on the
      same resource. An etag wildcard provide optimistic concurrency based on
      the expected existence of the flag. The Any wildcard (`*`) requires that
      the resource must already exists, and the Not Any wildcard (`!*`)
      requires that it must not.
    name: Required. The resource name of the resource within a service.
    requestId: An optional 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 since 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).
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   r   Tr?  r   r:   NrG  r   r   r   rg  rg    rH  r   rg  c                   8    e Zd ZdZ ej
                  dd      Zy)/SaasservicemgmtProjectsLocationsFlagsGetRequestzA SaasservicemgmtProjectsLocationsFlagsGetRequest object.

  Fields:
    name: Required. The resource name of the resource within a service.
  r
   Tr?  Nr   r   r   r   ri  ri    rK  r   ri  c                       e Zd ZdZ ej
                  d      Z ej
                  d      Z ej                  dej                  j                        Z ej
                  d      Z ej
                  dd	      Zy
)0SaasservicemgmtProjectsLocationsFlagsListRequesta  A SaasservicemgmtProjectsLocationsFlagsListRequest object.

  Fields:
    filter: Filter the list as specified in https://google.aip.dev/160.
    orderBy: Order results as specified in https://google.aip.dev/132.
    pageSize: The maximum number of flags to send per page.
    pageToken: The page token: If the next_page_token from a previous response
      is provided, this request will send the subsequent page.
    parent: Required. The parent of the flag.
  r
   r   r   r   r:   rY   Tr?  NrN  r   r   r   rk  rk    rS  r   rk  c                       e Zd ZdZ ej
                  dd      Z ej                  dd      Z ej                  d      Z	 ej                  d      Z
 ej                  d	      Zy
)1SaasservicemgmtProjectsLocationsFlagsPatchRequestay  A SaasservicemgmtProjectsLocationsFlagsPatchRequest object.

  Fields:
    flag: A Flag resource to be passed as the request body.
    name: Identifier. The resource name (full URI of the resource) following
      the standard naming scheme:
      "projects/{project}/locations/{location}/flags/{flag_id}"
    requestId: An optional 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 since 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: Field mask is used to specify the fields to be overwritten in
      the Flag resource by the update. The fields specified in the update_mask
      are relative to the resource, not the full request. A field will be
      overwritten if it is in the mask. If the user does not provide a mask
      then all fields in the Flag will be overwritten.
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r7   r
   r   Tr?  r   r:   rY   N)r   r   r   r   r   r4   r   r   ri   rC  rV  r2  rD  r   r   r   rm  rm    sg    8 
 			*$			q4	0$#i##A&)$y$$Q'*'''*,r   rm  c                   8    e Zd ZdZ ej
                  dd      Zy)*SaasservicemgmtProjectsLocationsGetRequestzlA SaasservicemgmtProjectsLocationsGetRequest object.

  Fields:
    name: Resource name for the location.
  r
   Tr?  Nr   r   r   r   ro  ro    rK  r   ro  c                       e Zd ZdZ ej
                  dd      Z ej
                  d      Z ej
                  dd      Z ej                  dej                  j                  	      Z ej
                  d
      Zy)+SaasservicemgmtProjectsLocationsListRequesta  A SaasservicemgmtProjectsLocationsListRequest 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).
    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
   Tr1   r   r   r?  r:   r   rY   N)r   r   r   r   r   r   extraLocationTypesrO  ri   r   r   r   rQ  rR  r   r   r   rq  rq  $  sv      -y,,Q> 9  #&			q4	0$#Y##Ay/@/@/F/FG(#i##A&)r   rq  c                       e Zd ZdZ ej
                  dd      Z ej                  dd      Z ej
                  d      Z	 ej
                  d      Z
 ej                  d	      Zy
)5SaasservicemgmtProjectsLocationsReleasesCreateRequesta  A SaasservicemgmtProjectsLocationsReleasesCreateRequest object.

  Fields:
    parent: Required. The parent of the release.
    release: A Release resource to be passed as the request body.
    releaseId: Required. The ID value for the new release.
    requestId: An optional 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 since 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).
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   Tr?  r   r   r   r:   rY   N)r   r   r   r   r   r   rB  r4   r   	releaseIdrC  r2  rD  r   r   r   rt  rt  <  sg    , !9  T2&"I""9a0'#i##A&)#i##A&)'''*,r   rt  c                       e Zd ZdZ ej
                  d      Z ej
                  dd      Z ej
                  d      Z ej                  d      Z
y)	5SaasservicemgmtProjectsLocationsReleasesDeleteRequestaZ  A SaasservicemgmtProjectsLocationsReleasesDeleteRequest object.

  Fields:
    etag: The etag known to the client for the expected state of the release.
      This is used with state-changing methods to prevent accidental
      overwrites when multiple user agents might be acting in parallel on the
      same resource. An etag wildcard provide optimistic concurrency based on
      the expected existence of the release. The Any wildcard (`*`) requires
      that the resource must already exists, and the Not Any wildcard (`!*`)
      requires that it must not.
    name: Required. The resource name of the resource within a service.
    requestId: An optional 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 since 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).
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   r   Tr?  r   r:   NrG  r   r   r   rw  rw  Z  rH  r   rw  c                   8    e Zd ZdZ ej
                  dd      Zy)2SaasservicemgmtProjectsLocationsReleasesGetRequestzA SaasservicemgmtProjectsLocationsReleasesGetRequest object.

  Fields:
    name: Required. The resource name of the resource within a service.
  r
   Tr?  Nr   r   r   r   ry  ry  |  rK  r   ry  c                       e Zd ZdZ ej
                  d      Z ej
                  d      Z ej                  dej                  j                        Z ej
                  d      Z ej
                  dd	      Zy
)3SaasservicemgmtProjectsLocationsReleasesListRequesta  A SaasservicemgmtProjectsLocationsReleasesListRequest object.

  Fields:
    filter: Filter the list as specified in https://google.aip.dev/160.
    orderBy: Order results as specified in https://google.aip.dev/132.
    pageSize: The maximum number of releases to send per page.
    pageToken: The page token: If the next_page_token from a previous response
      is provided, this request will send the subsequent page.
    parent: Required. The parent of the release.
  r
   r   r   r   r:   rY   Tr?  NrN  r   r   r   r{  r{    rS  r   r{  c                       e Zd ZdZ ej
                  dd      Z ej                  dd      Z ej
                  d      Z	 ej
                  d      Z
 ej                  d	      Zy
)4SaasservicemgmtProjectsLocationsReleasesPatchRequesta  A SaasservicemgmtProjectsLocationsReleasesPatchRequest object.

  Fields:
    name: Identifier. The resource name (full URI of the resource) following
      the standard naming scheme:
      "projects/{project}/locations/{location}/releases/{release}"
    release: A Release resource to be passed as the request body.
    requestId: An optional 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 since 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: Field mask is used to specify the fields to be overwritten in
      the Release resource by the update. The fields specified in the
      update_mask are relative to the resource, not the full request. A field
      will be overwritten if it is in the mask. If the user does not provide a
      mask then all fields in the Release will be overwritten.
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   Tr?  r   r   r   r:   rY   N)r   r   r   r   r   r   ri   r4   r   rC  rV  r2  rD  r   r   r   r}  r}    sg    8 
		q4	0$"I""9a0'#i##A&)$y$$Q'*'''*,r   r}  c                       e Zd ZdZ ej
                  dd      Z ej
                  d      Z ej                  dd      Z	 ej
                  d      Z
 ej                  d	      Zy
)9SaasservicemgmtProjectsLocationsRolloutKindsCreateRequesta  A SaasservicemgmtProjectsLocationsRolloutKindsCreateRequest object.

  Fields:
    parent: Required. The parent of the rollout kind.
    requestId: An optional 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 since 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).
    rolloutKind: A RolloutKind resource to be passed as the request body.
    rolloutKindId: Required. The ID value for the new rollout kind.
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   Tr?  r   r   r   r:   rY   N)r   r   r   r   r   r   rB  rC  r4   r
  rolloutKindIdr2  rD  r   r   r   r  r    sg    , !9  T2&#i##A&)&	&&}a8+')''*-'''*,r   r  c                       e Zd ZdZ ej
                  d      Z ej
                  dd      Z ej
                  d      Z ej                  d      Z
y)	9SaasservicemgmtProjectsLocationsRolloutKindsDeleteRequestah  A SaasservicemgmtProjectsLocationsRolloutKindsDeleteRequest object.

  Fields:
    etag: The etag known to the client for the expected state of the rollout
      kind. This is used with state-changing methods to prevent accidental
      overwrites when multiple user agents might be acting in parallel on the
      same resource. An etag wildcard provide optimistic concurrency based on
      the expected existence of the rollout kind. The Any wildcard (`*`)
      requires that the resource must already exists, and the Not Any wildcard
      (`!*`) requires that it must not.
    name: Required. The resource name of the resource within a service.
    requestId: An optional 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 since 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).
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   r   Tr?  r   r:   NrG  r   r   r   r  r    rH  r   r  c                   8    e Zd ZdZ ej
                  dd      Zy)6SaasservicemgmtProjectsLocationsRolloutKindsGetRequestzA SaasservicemgmtProjectsLocationsRolloutKindsGetRequest object.

  Fields:
    name: Required. The resource name of the resource within a service.
  r
   Tr?  Nr   r   r   r   r  r    rK  r   r  c                       e Zd ZdZ ej
                  d      Z ej
                  d      Z ej                  dej                  j                        Z ej
                  d      Z ej
                  dd	      Zy
)7SaasservicemgmtProjectsLocationsRolloutKindsListRequesta  A SaasservicemgmtProjectsLocationsRolloutKindsListRequest object.

  Fields:
    filter: Filter the list as specified in https://google.aip.dev/160.
    orderBy: Order results as specified in https://google.aip.dev/132.
    pageSize: The maximum number of rollout kinds to send per page.
    pageToken: The page token: If the next_page_token from a previous response
      is provided, this request will send the subsequent page.
    parent: Required. The parent of the rollout kind.
  r
   r   r   r   r:   rY   Tr?  NrN  r   r   r   r  r    rS  r   r  c                       e Zd ZdZ ej
                  dd      Z ej
                  d      Z ej                  dd      Z	 ej
                  d      Z
 ej                  d	      Zy
)8SaasservicemgmtProjectsLocationsRolloutKindsPatchRequesta  A SaasservicemgmtProjectsLocationsRolloutKindsPatchRequest object.

  Fields:
    name: Identifier. The resource name (full URI of the resource) following
      the standard naming scheme:
      "projects/{project}/locations/{location}/rolloutKinds/{rollout_kind_id}"
    requestId: An optional 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 since 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).
    rolloutKind: A RolloutKind resource to be passed as the request body.
    updateMask: Field mask is used to specify the fields to be overwritten in
      the RolloutKind resource by the update. The fields specified in the
      update_mask are relative to the resource, not the full request. A field
      will be overwritten if it is in the mask. If the user does not provide a
      mask then all fields in the RolloutKind will be overwritten.
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   Tr?  r   r   r   r:   rY   N)r   r   r   r   r   r   ri   rC  r4   r
  rV  r2  rD  r   r   r   r  r    sg    8 
		q4	0$#i##A&)&	&&}a8+$y$$Q'*'''*,r   r  c                       e Zd ZdZ ej
                  dd      Z ej
                  d      Z ej                  dd      Z	 ej
                  d      Z
 ej                  d	      Zy
)5SaasservicemgmtProjectsLocationsRolloutsCreateRequesta  A SaasservicemgmtProjectsLocationsRolloutsCreateRequest object.

  Fields:
    parent: Required. The parent of the rollout.
    requestId: An optional 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 since 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).
    rollout: A Rollout resource to be passed as the request body.
    rolloutId: Required. The ID value for the new rollout.
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   Tr?  r   r   r   r:   rY   N)r   r   r   r   r   r   rB  rC  r4   rollout	rolloutIdr2  rD  r   r   r   r  r  >  sg    , !9  T2&#i##A&)"I""9a0'#i##A&)'''*,r   r  c                       e Zd ZdZ ej
                  d      Z ej
                  dd      Z ej
                  d      Z ej                  d      Z
y)	5SaasservicemgmtProjectsLocationsRolloutsDeleteRequestaZ  A SaasservicemgmtProjectsLocationsRolloutsDeleteRequest object.

  Fields:
    etag: The etag known to the client for the expected state of the rollout.
      This is used with state-changing methods to prevent accidental
      overwrites when multiple user agents might be acting in parallel on the
      same resource. An etag wildcard provide optimistic concurrency based on
      the expected existence of the rollout. The Any wildcard (`*`) requires
      that the resource must already exists, and the Not Any wildcard (`!*`)
      requires that it must not.
    name: Required. The resource name of the resource within a service.
    requestId: An optional 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 since 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).
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   r   Tr?  r   r:   NrG  r   r   r   r  r  \  rH  r   r  c                   8    e Zd ZdZ ej
                  dd      Zy)2SaasservicemgmtProjectsLocationsRolloutsGetRequestzA SaasservicemgmtProjectsLocationsRolloutsGetRequest object.

  Fields:
    name: Required. The resource name of the resource within a service.
  r
   Tr?  Nr   r   r   r   r  r  ~  rK  r   r  c                       e Zd ZdZ ej
                  d      Z ej
                  d      Z ej                  dej                  j                        Z ej
                  d      Z ej
                  dd	      Zy
)3SaasservicemgmtProjectsLocationsRolloutsListRequesta  A SaasservicemgmtProjectsLocationsRolloutsListRequest object.

  Fields:
    filter: Filter the list as specified in https://google.aip.dev/160.
    orderBy: Order results as specified in https://google.aip.dev/132.
    pageSize: The maximum number of rollouts to send per page.
    pageToken: The page token: If the next_page_token from a previous response
      is provided, this request will send the subsequent page.
    parent: Required. The parent of the rollout.
  r
   r   r   r   r:   rY   Tr?  NrN  r   r   r   r  r    rS  r   r  c                       e Zd ZdZ ej
                  dd      Z ej
                  d      Z ej                  dd      Z	 ej
                  d      Z
 ej                  d	      Zy
)4SaasservicemgmtProjectsLocationsRolloutsPatchRequesta  A SaasservicemgmtProjectsLocationsRolloutsPatchRequest object.

  Fields:
    name: Identifier. The resource name (full URI of the resource) following
      the standard naming scheme:
      "projects/{project}/locations/{location}/rollout/{rollout_id}"
    requestId: An optional 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 since 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).
    rollout: A Rollout resource to be passed as the request body.
    updateMask: Field mask is used to specify the fields to be overwritten in
      the Rollout resource by the update. The fields specified in the
      update_mask are relative to the resource, not the full request. A field
      will be overwritten if it is in the mask. If the user does not provide a
      mask then all fields in the Rollout will be overwritten.
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   Tr?  r   r   r   r:   rY   N)r   r   r   r   r   r   ri   rC  r4   r  rV  r2  rD  r   r   r   r  r    sg    8 
		q4	0$#i##A&)"I""9a0'$y$$Q'*'''*,r   r  c                       e Zd ZdZ ej
                  dd      Z ej
                  d      Z ej                  dd      Z	 ej
                  d      Z
 ej                  d	      Zy
)1SaasservicemgmtProjectsLocationsSaasCreateRequesta  A SaasservicemgmtProjectsLocationsSaasCreateRequest object.

  Fields:
    parent: Required. The parent of the saas.
    requestId: An optional 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 since 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).
    saas: A Saas resource to be passed as the request body.
    saasId: Required. The ID value for the new saas.
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   Tr?  r   r   r   r:   rY   N)r   r   r   r   r   r   rB  rC  r4   r   saasIdr2  rD  r   r   r   r  r    g    , !9  T2&#i##A&)				*$ 9  #&'''*,r   r  c                       e Zd ZdZ ej
                  d      Z ej
                  dd      Z ej
                  d      Z ej                  d      Z
y)	1SaasservicemgmtProjectsLocationsSaasDeleteRequestaP  A SaasservicemgmtProjectsLocationsSaasDeleteRequest object.

  Fields:
    etag: The etag known to the client for the expected state of the saas.
      This is used with state-changing methods to prevent accidental
      overwrites when multiple user agents might be acting in parallel on the
      same resource. An etag wildcard provide optimistic concurrency based on
      the expected existence of the saas. The Any wildcard (`*`) requires that
      the resource must already exists, and the Not Any wildcard (`!*`)
      requires that it must not.
    name: Required. The resource name of the resource within a service.
    requestId: An optional 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 since 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).
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   r   Tr?  r   r:   NrG  r   r   r   r  r    rH  r   r  c                   8    e Zd ZdZ ej
                  dd      Zy).SaasservicemgmtProjectsLocationsSaasGetRequestzA SaasservicemgmtProjectsLocationsSaasGetRequest object.

  Fields:
    name: Required. The resource name of the resource within a service.
  r
   Tr?  Nr   r   r   r   r  r    rK  r   r  c                       e Zd ZdZ ej
                  d      Z ej
                  d      Z ej                  dej                  j                        Z ej
                  d      Z ej
                  dd	      Zy
)/SaasservicemgmtProjectsLocationsSaasListRequesta  A SaasservicemgmtProjectsLocationsSaasListRequest object.

  Fields:
    filter: Filter the list as specified in https://google.aip.dev/160.
    orderBy: Order results as specified in https://google.aip.dev/132.
    pageSize: The maximum number of saas to send per page.
    pageToken: The page token: If the next_page_token from a previous response
      is provided, this request will send the subsequent page.
    parent: Required. The parent of the saas.
  r
   r   r   r   r:   rY   Tr?  NrN  r   r   r   r  r  		  rS  r   r  c                       e Zd ZdZ ej
                  dd      Z ej
                  d      Z ej                  dd      Z	 ej
                  d      Z
 ej                  d	      Zy
)0SaasservicemgmtProjectsLocationsSaasPatchRequestat  A SaasservicemgmtProjectsLocationsSaasPatchRequest object.

  Fields:
    name: Identifier. The resource name (full URI of the resource) following
      the standard naming scheme:
      "projects/{project}/locations/{location}/saas/{saas}"
    requestId: An optional 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 since 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).
    saas: A Saas resource to be passed as the request body.
    updateMask: Field mask is used to specify the fields to be overwritten in
      the Saas resource by the update. The fields specified in the update_mask
      are relative to the resource, not the full request. A field will be
      overwritten if it is in the mask. If the user does not provide a mask
      then all fields in the Saas will be overwritten.
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   Tr?  r   r   r   r:   rY   N)r   r   r   r   r   r   ri   rC  r4   r   rV  r2  rD  r   r   r   r  r  	  g    8 
		q4	0$#i##A&)				*$$y$$Q'*'''*,r   r  c                       e Zd ZdZ ej
                  dd      Z ej
                  d      Z ej                  dd      Z	 ej
                  d      Z
 ej                  d	      Zy
)4SaasservicemgmtProjectsLocationsTenantsCreateRequesta  A SaasservicemgmtProjectsLocationsTenantsCreateRequest object.

  Fields:
    parent: Required. The parent of the tenant.
    requestId: An optional 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 since 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).
    tenant: A Tenant resource to be passed as the request body.
    tenantId: Required. The ID value for the new tenant.
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   Tr?  r   r   r   r:   rY   N)r   r   r   r   r   r   rB  rC  r4   tenanttenantIdr2  rD  r   r   r   r  r  @	  sg    , !9  T2&#i##A&)!9!!(A.&"Y""1%('''*,r   r  c                       e Zd ZdZ ej
                  d      Z ej
                  dd      Z ej
                  d      Z ej                  d      Z
y)	4SaasservicemgmtProjectsLocationsTenantsDeleteRequestaW  A SaasservicemgmtProjectsLocationsTenantsDeleteRequest object.

  Fields:
    etag: The etag known to the client for the expected state of the tenant.
      This is used with state-changing methods to prevent accidental
      overwrites when multiple user agents might be acting in parallel on the
      same resource. An etag wildcard provide optimistic concurrency based on
      the expected existence of the tenant. The Any wildcard (`*`) requires
      that the resource must already exists, and the Not Any wildcard (`!*`)
      requires that it must not.
    name: Required. The resource name of the resource within a service.
    requestId: An optional 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 since 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).
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   r   Tr?  r   r:   NrG  r   r   r   r  r  ^	  rH  r   r  c                   8    e Zd ZdZ ej
                  dd      Zy)1SaasservicemgmtProjectsLocationsTenantsGetRequestzA SaasservicemgmtProjectsLocationsTenantsGetRequest object.

  Fields:
    name: Required. The resource name of the resource within a service.
  r
   Tr?  Nr   r   r   r   r  r  	  rK  r   r  c                       e Zd ZdZ ej
                  d      Z ej
                  d      Z ej                  dej                  j                        Z ej
                  d      Z ej
                  dd	      Zy
)2SaasservicemgmtProjectsLocationsTenantsListRequesta  A SaasservicemgmtProjectsLocationsTenantsListRequest object.

  Fields:
    filter: Filter the list as specified in https://google.aip.dev/160.
    orderBy: Order results as specified in https://google.aip.dev/132.
    pageSize: The maximum number of tenants to send per page.
    pageToken: The page token: If the next_page_token from a previous response
      is provided, this request will send the subsequent page.
    parent: Required. The parent of the tenant.
  r
   r   r   r   r:   rY   Tr?  NrN  r   r   r   r  r  	  rS  r   r  c                       e Zd ZdZ ej
                  dd      Z ej
                  d      Z ej                  dd      Z	 ej
                  d      Z
 ej                  d	      Zy
)3SaasservicemgmtProjectsLocationsTenantsPatchRequesta  A SaasservicemgmtProjectsLocationsTenantsPatchRequest object.

  Fields:
    name: Identifier. The resource name (full URI of the resource) following
      the standard naming scheme:
      "projects/{project}/locations/{location}/tenants/{tenant}"
    requestId: An optional 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 since 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).
    tenant: A Tenant resource to be passed as the request body.
    updateMask: Field mask is used to specify the fields to be overwritten in
      the Tenant resource by the update. The fields specified in the
      update_mask are relative to the resource, not the full request. A field
      will be overwritten if it is in the mask. If the user does not provide a
      mask then all fields in the Tenant will be overwritten.
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   Tr?  r   r   r   r:   rY   N)r   r   r   r   r   r   ri   rC  r4   r  rV  r2  rD  r   r   r   r  r  	  sg    8 
		q4	0$#i##A&)!9!!(A.&$y$$Q'*'''*,r   r  c                       e Zd ZdZ ej
                  dd      Z ej
                  d      Z ej                  dd      Z	 ej
                  d      Z
 ej                  d	      Zy
)6SaasservicemgmtProjectsLocationsUnitKindsCreateRequesta  A SaasservicemgmtProjectsLocationsUnitKindsCreateRequest object.

  Fields:
    parent: Required. The parent of the unit kind.
    requestId: An optional 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 since 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).
    unitKind: A UnitKind resource to be passed as the request body.
    unitKindId: Required. The ID value for the new unit kind.
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   Tr?  r   r   r   r:   rY   N)r   r   r   r   r   r   rB  rC  r4   r%   
unitKindIdr2  rD  r   r   r   r  r  	  sg    , !9  T2&#i##A&)#Y##J2($y$$Q'*'''*,r   r  c                       e Zd ZdZ ej
                  d      Z ej
                  dd      Z ej
                  d      Z ej                  d      Z
y)	6SaasservicemgmtProjectsLocationsUnitKindsDeleteRequesta_  A SaasservicemgmtProjectsLocationsUnitKindsDeleteRequest object.

  Fields:
    etag: The etag known to the client for the expected state of the unit
      kind. This is used with state-changing methods to prevent accidental
      overwrites when multiple user agents might be acting in parallel on the
      same resource. An etag wildcard provide optimistic concurrency based on
      the expected existence of the unit kind. The Any wildcard (`*`) requires
      that the resource must already exists, and the Not Any wildcard (`!*`)
      requires that it must not.
    name: Required. The resource name of the resource within a service.
    requestId: An optional 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 since 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).
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   r   Tr?  r   r:   NrG  r   r   r   r  r  	  rH  r   r  c                   8    e Zd ZdZ ej
                  dd      Zy)3SaasservicemgmtProjectsLocationsUnitKindsGetRequestzA SaasservicemgmtProjectsLocationsUnitKindsGetRequest object.

  Fields:
    name: Required. The resource name of the resource within a service.
  r
   Tr?  Nr   r   r   r   r  r  
  rK  r   r  c                       e Zd ZdZ ej
                  d      Z ej
                  d      Z ej                  dej                  j                        Z ej
                  d      Z ej
                  dd	      Zy
)4SaasservicemgmtProjectsLocationsUnitKindsListRequesta  A SaasservicemgmtProjectsLocationsUnitKindsListRequest object.

  Fields:
    filter: Filter the list as specified in https://google.aip.dev/160.
    orderBy: Order results as specified in https://google.aip.dev/132.
    pageSize: The maximum number of unit kinds to send per page.
    pageToken: The page token: If the next_page_token from a previous response
      is provided, this request will send the subsequent page.
    parent: Required. The parent of the unit kind.
  r
   r   r   r   r:   rY   Tr?  NrN  r   r   r   r  r  
  rS  r   r  c                       e Zd ZdZ ej
                  dd      Z ej
                  d      Z ej                  dd      Z	 ej
                  d      Z
 ej                  d	      Zy
)5SaasservicemgmtProjectsLocationsUnitKindsPatchRequesta  A SaasservicemgmtProjectsLocationsUnitKindsPatchRequest object.

  Fields:
    name: Identifier. The resource name (full URI of the resource) following
      the standard naming scheme:
      "projects/{project}/locations/{location}/unitKinds/{unitKind}"
    requestId: An optional 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 since 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).
    unitKind: A UnitKind resource to be passed as the request body.
    updateMask: Field mask is used to specify the fields to be overwritten in
      the UnitKind resource by the update. The fields specified in the
      update_mask are relative to the resource, not the full request. A field
      will be overwritten if it is in the mask. If the user does not provide a
      mask then all fields in the UnitKind will be overwritten.
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   Tr?  r   r   r   r:   rY   N)r   r   r   r   r   r   ri   rC  r4   r%   rV  r2  rD  r   r   r   r  r  
  sg    8 
		q4	0$#i##A&)#Y##J2($y$$Q'*'''*,r   r  c                       e Zd ZdZ ej
                  dd      Z ej
                  d      Z ej                  dd      Z	 ej
                  d      Z
 ej                  d	      Zy
);SaasservicemgmtProjectsLocationsUnitOperationsCreateRequesta  A SaasservicemgmtProjectsLocationsUnitOperationsCreateRequest object.

  Fields:
    parent: Required. The parent of the unit operation.
    requestId: An optional 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 since 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).
    unitOperation: A UnitOperation resource to be passed as the request body.
    unitOperationId: Required. The ID value for the new unit operation.
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   Tr?  r   r   r   r:   rY   N)r   r   r   r   r   r   rB  rC  r4   unitOperationunitOperationIdr2  rD  r   r   r   r  r  B
  sg    , !9  T2&#i##A&)()((!<-)I))!,/'''*,r   r  c                       e Zd ZdZ ej
                  d      Z ej
                  dd      Z ej
                  d      Z ej                  d      Z
y)	;SaasservicemgmtProjectsLocationsUnitOperationsDeleteRequestan  A SaasservicemgmtProjectsLocationsUnitOperationsDeleteRequest object.

  Fields:
    etag: The etag known to the client for the expected state of the unit
      operation. This is used with state-changing methods to prevent
      accidental overwrites when multiple user agents might be acting in
      parallel on the same resource. An etag wildcard provide optimistic
      concurrency based on the expected existence of the unit operation. The
      Any wildcard (`*`) requires that the resource must already exists, and
      the Not Any wildcard (`!*`) requires that it must not.
    name: Required. The resource name of the resource within a service.
    requestId: An optional 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 since 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).
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   r   Tr?  r   r:   NrG  r   r   r   r  r  `
  rH  r   r  c                   8    e Zd ZdZ ej
                  dd      Zy)8SaasservicemgmtProjectsLocationsUnitOperationsGetRequestzA SaasservicemgmtProjectsLocationsUnitOperationsGetRequest object.

  Fields:
    name: Required. The resource name of the resource within a service.
  r
   Tr?  Nr   r   r   r   r  r  
  rK  r   r  c                       e Zd ZdZ ej
                  d      Z ej
                  d      Z ej                  dej                  j                        Z ej
                  d      Z ej
                  dd	      Zy
)9SaasservicemgmtProjectsLocationsUnitOperationsListRequesta  A SaasservicemgmtProjectsLocationsUnitOperationsListRequest object.

  Fields:
    filter: Filter the list as specified in https://google.aip.dev/160.
    orderBy: Order results as specified in https://google.aip.dev/132.
    pageSize: The maximum number of unit operations to send per page.
    pageToken: The page token: If the next_page_token from a previous response
      is provided, this request will send the subsequent page.
    parent: Required. The parent of the unit operation.
  r
   r   r   r   r:   rY   Tr?  NrN  r   r   r   r  r  
  rS  r   r  c                       e Zd ZdZ ej
                  dd      Z ej
                  d      Z ej                  dd      Z	 ej
                  d      Z
 ej                  d	      Zy
):SaasservicemgmtProjectsLocationsUnitOperationsPatchRequesta  A SaasservicemgmtProjectsLocationsUnitOperationsPatchRequest object.

  Fields:
    name: Identifier. The resource name (full URI of the resource) following
      the standard naming scheme:
      "projects/{project}/locations/{location}/unitOperations/{unitOperation}"
    requestId: An optional 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 since 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).
    unitOperation: A UnitOperation resource to be passed as the request body.
    updateMask: Field mask is used to specify the fields to be overwritten in
      the UnitOperation resource by the update. The fields specified in the
      update_mask are relative to the resource, not the full request. A field
      will be overwritten if it is in the mask. If the user does not provide a
      mask then all fields in the UnitOperation will be overwritten.
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   Tr?  r   r   r   r:   rY   N)r   r   r   r   r   r   ri   rC  r4   r  rV  r2  rD  r   r   r   r  r  
  sg    8 
		q4	0$#i##A&)()((!<-$y$$Q'*'''*,r   r  c                       e Zd ZdZ ej
                  dd      Z ej
                  d      Z ej                  dd      Z	 ej
                  d      Z
 ej                  d	      Zy
)2SaasservicemgmtProjectsLocationsUnitsCreateRequesta  A SaasservicemgmtProjectsLocationsUnitsCreateRequest object.

  Fields:
    parent: Required. The parent of the unit.
    requestId: An optional 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 since 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).
    unit: A Unit resource to be passed as the request body.
    unitId: Required. The ID value for the new unit.
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   Tr?  r   r   r   r:   rY   N)r   r   r   r   r   r   rB  rC  r4   unitunitIdr2  rD  r   r   r   r  r  
  r  r   r  c                       e Zd ZdZ ej
                  d      Z ej
                  dd      Z ej
                  d      Z ej                  d      Z
y)	2SaasservicemgmtProjectsLocationsUnitsDeleteRequestaQ  A SaasservicemgmtProjectsLocationsUnitsDeleteRequest object.

  Fields:
    etag: The etag known to the client for the expected state of the unit.
      This is used with state-changing methods to prevent accidental
      overwrites when multiple user agents might be acting in parallel on the
      same resource. An etag wildcard provide optimistic concurrency based on
      the expected existence of the unit. The Any wildcard (`*`) requires that
      the resource must already exists, and the Not Any wildcard (`!*`)
      requires that it must not.
    name: Required. The resource name of the resource within a service.
    requestId: An optional 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 since 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).
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   r   Tr?  r   r:   NrG  r   r   r   r  r  
  rH  r   r  c                   8    e Zd ZdZ ej
                  dd      Zy)/SaasservicemgmtProjectsLocationsUnitsGetRequestzA SaasservicemgmtProjectsLocationsUnitsGetRequest object.

  Fields:
    name: Required. The resource name of the resource within a service.
  r
   Tr?  Nr   r   r   r   r  r    rK  r   r  c                       e Zd ZdZ ej
                  d      Z ej
                  d      Z ej                  dej                  j                        Z ej
                  d      Z ej
                  dd	      Zy
)0SaasservicemgmtProjectsLocationsUnitsListRequesta  A SaasservicemgmtProjectsLocationsUnitsListRequest object.

  Fields:
    filter: Filter the list as specified in https://google.aip.dev/160.
    orderBy: Order results as specified in https://google.aip.dev/132.
    pageSize: The maximum number of units to send per page.
    pageToken: The page token: If the next_page_token from a previous response
      is provided, this request will send the subsequent page.
    parent: Required. The parent of the unit.
  r
   r   r   r   r:   rY   Tr?  NrN  r   r   r   r  r    rS  r   r  c                       e Zd ZdZ ej
                  dd      Z ej
                  d      Z ej                  dd      Z	 ej
                  d      Z
 ej                  d	      Zy
)1SaasservicemgmtProjectsLocationsUnitsPatchRequestav  A SaasservicemgmtProjectsLocationsUnitsPatchRequest object.

  Fields:
    name: Identifier. The resource name (full URI of the resource) following
      the standard naming scheme:
      "projects/{project}/locations/{location}/units/{unit}"
    requestId: An optional 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 since 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).
    unit: A Unit resource to be passed as the request body.
    updateMask: Field mask is used to specify the fields to be overwritten in
      the Unit resource by the update. The fields specified in the update_mask
      are relative to the resource, not the full request. A field will be
      overwritten if it is in the mask. If the user does not provide a mask
      then all fields in the Unit will be overwritten.
    validateOnly: If "validate_only" is set to true, the service will try to
      validate that this request would succeed, but will not actually make
      changes.
  r
   Tr?  r   r   r   r:   rY   N)r   r   r   r   r   r   ri   rC  r4   r  rV  r2  rD  r   r   r   r  r     r  r   r  c                   4    e Zd ZdZ ej
                  d      Zy)SchedulezA time specification to schedule the maintenance.

  Fields:
    startTime: Optional. Start of operation. If not set, will be set to the
      start of the next window. (optional)
  r
   N)r   r   r   r   r   r   r  r   r   r   r  r  D  s     $i##A&)r   r  c                       e Zd ZdZ G d dej
                        Z G d dej
                        Z ej                  dd      Z	 ej                  d      Z ej                  ddd	
      Z ej                  d      Z ej                  d      Z ej                  d      Z ej                  d      Z ej"                  dd
      Z ej                  d      Z ej                  d      Z ej                  d      Z ej                  d      Zy)StandardQueryParametersa4  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                       e Zd ZdZdZdZdZy)*StandardQueryParameters.AltValueValuesEnumzData 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   N)r   r   r   r   jsonmediaprotor   r   r   AltValueValuesEnumr  j  s     DEEr   r  c                       e Zd ZdZdZdZy)-StandardQueryParameters.FXgafvValueValuesEnumzVV1 error format.

    Values:
      _1: v1 error format
      _2: v2 error format
    r   r
   N)r   r   r   r   _1_2r   r   r   FXgafvValueValuesEnumr  v  s     
B	
Br   r  r
   r   r   r  )defaultr:   rY   rZ   r[   r\   Tr]   r^   r_   r`   N)r   r   r   r   r   ra   r  r  rl   f__xgafvr   access_tokenaltcallbackfieldsrI   oauth_tokenr2  prettyPrint	quotaUsertrace
uploadTypeupload_protocolr   r   r   r  r  O  s   4
9>> 
inn  !Y  !8!<(&&&q),	0!VD#"Y""1%( 9  #&	a #%	%%a(+&	&&q$7+#i##A&)
)


#%$y$$R(*)I))"-/r   r  c                       e Zd ZdZ ej
                  d       G d dej                               Z ej
                  d       G d dej                               Z	 ej                  dd      Z ej                  d      Z ej                  d	      Z ej                  d
      Z ej                  dd      Z ej                  d      Z ej                  d      Z ej                  d      Z ej                  d      Zy)r   av  Tenant represents the service producer side of an instance of the
  service created based on a request from a consumer. In a typical scenario a
  Tenant has a one-to-one mapping with a resource given out to a service
  consumer. Example: tenant: name:
  "projects/svc1/locations/loc/tenants/inst-068afff8" consumer_resource:
  "projects/gshoe/locations/loc/shoes/black-shoe"

  Messages:
    AnnotationsValue: Optional. Annotations is an unstructured key-value map
      stored with a resource that may be set by external tools to store and
      retrieve arbitrary metadata. They are not queryable and should be
      preserved when modifying objects. More info:
      https://kubernetes.io/docs/user-guide/annotations
    LabelsValue: Optional. The labels on the resource, which can be used for
      categorization. similar to Kubernetes resource labels.

  Fields:
    annotations: Optional. Annotations is an unstructured key-value map stored
      with a resource that may be set by external tools to store and retrieve
      arbitrary metadata. They are not queryable and should be preserved when
      modifying objects. More info: https://kubernetes.io/docs/user-
      guide/annotations
    consumerResource: Optional. Immutable. A reference to the consumer
      resource this SaaS Tenant is representing. The relationship with a
      consumer resource can be used by SaaS Runtime for retrieving consumer-
      defined settings and policies such as maintenance policies (using
      Unified Maintenance Policy API).
    createTime: Output only. The timestamp when the resource was created.
    etag: Output only. An opaque value that uniquely identifies a version or
      generation of a resource. It can be used to confirm that the client and
      server agree on the ordering of a resource being written.
    labels: Optional. The labels on the resource, which can be used for
      categorization. similar to Kubernetes resource labels.
    name: Identifier. The resource name (full URI of the resource) following
      the standard naming scheme:
      "projects/{project}/locations/{location}/tenants/{tenant}"
    saas: Required. Immutable. A reference to the Saas that defines the
      product (managed service) that the producer wants to manage with SaaS
      Runtime. Part of the SaaS Runtime common data model.
    uid: Output only. The unique identifier of the resource. UID is unique in
      the time and space for this resource within the scope of the service. It
      is typically generated by the server on successful creation of a
      resource and must not be changed. UID is used to uniquely identify
      resources with resource name reuses. This should be a UUID4.
    updateTime: Output only. The timestamp when the resource was last updated.
      Any change to the resource made by users must refresh this value.
      Changes to a resource made by the service should refresh this value.
  rA   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)Tenant.AnnotationsValuerD   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)*Tenant.AnnotationsValue.AdditionalPropertyrG   r
   r   NrH   r   r   r   rK   r    rL   r   rK   r
   Tr1   NrM   r   r   r   rO   r    rP   r   rO   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)Tenant.LabelsValuerS   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)%Tenant.LabelsValue.AdditionalPropertyrV   r
   r   NrH   r   r   r   rK   r    rL   r   rK   r
   Tr1   NrM   r   r   r   rW   r    rX   r   rW   r
   r   r   r:   rY   rZ   r[   r\   r]   N)r   r   r   r   r   rb   r   rN   rO   rW   r4   rc   r   consumerResourcerd   rf   rh   ri   r   rj   rk   r   r   r   r   r     s   /b "8!!"89Z** Z :Z6 "8!!"89ZI%% Z :Z0 '	&&'91=+*Y**1-$y$$Q'*			q	!$!9!!-3&			q	!$			q	!$	a #$y$$Q'*r   r   c                   |    e Zd ZdZ ej
                  d      Z ej                  d      Z ej
                  d      Z	y)	ToMappingag  Input variables whose values will be passed on to dependencies

  Fields:
    dependency: Required. Alias of the dependency that the inputVariable will
      pass its value to
    ignoreForLookup: Optional. Tells SaaS Runtime if this mapping should be
      used during lookup or not
    inputVariable: Required. Name of the inputVariable on the dependency
  r
   r   r   N)
r   r   r   r   r   r   r   r2  ignoreForLookupinputVariabler   r   r   r  r     s?     %y$$Q'**I**1-/')''*-r   r  c                      e Zd ZdZ G d dej
                        Z G d dej
                        Z G d dej
                        Z e	j                  d       G d	 d
ej                               Z e	j                  d       G d dej                               Z ej                  d
d      Z ej                  ddd      Z ej"                  d      Z ej                  ddd      Z ej                  ddd      Z ej"                  d      Z ej"                  dd      Z ej                  ddd      Z ej                  dd      Z ej                  dd      Z ej4                  dd      Z ej"                  d      Z ej"                  dd      Z ej                  dd d      Z ej"                  d!d      Z ej"                  d"      Z  ej"                  d#d      Z! ej4                  dd$      Z" ej"                  d%      Z# ej4                  dd&      Z$ ej"                  d'      Z% ej"                  d(      Z& ej"                  d)      Z' ej"                  d*      Z(y+),r   a  A unit of deployment that has its lifecycle via a CRUD API using an
  actuation engine under the hood (e.g. based on Terraform, Helm or a custom
  implementation provided by a service producer). A building block of a SaaS
  Tenant.

  Enums:
    ManagementModeValueValuesEnum: Optional. Immutable. Indicates whether the
      Unit life cycle is controlled by the user or by the system. Immutable
      once created.
    StateValueValuesEnum: Optional. Output only. Current lifecycle state of
      the resource (e.g. if it's being created or ready to use).
    SystemManagedStateValueValuesEnum: Optional. Output only. Indicates the
      system managed state of the unit.

  Messages:
    AnnotationsValue: Optional. Annotations is an unstructured key-value map
      stored with a resource that may be set by external tools to store and
      retrieve arbitrary metadata. They are not queryable and should be
      preserved when modifying objects. More info:
      https://kubernetes.io/docs/user-guide/annotations
    LabelsValue: Optional. The labels on the resource, which can be used for
      categorization. similar to Kubernetes resource labels.

  Fields:
    annotations: Optional. Annotations is an unstructured key-value map stored
      with a resource that may be set by external tools to store and retrieve
      arbitrary metadata. They are not queryable and should be preserved when
      modifying objects. More info: https://kubernetes.io/docs/user-
      guide/annotations
    conditions: Optional. Output only. A set of conditions which indicate the
      various conditions this resource can have.
    createTime: Output only. The timestamp when the resource was created.
    dependencies: Optional. Output only. Set of dependencies for this unit.
      Maximum 10.
    dependents: Optional. Output only. List of Units that depend on this unit.
      Unit can only be deprovisioned if this list is empty. Maximum 1000.
    etag: Output only. An opaque value that uniquely identifies a version or
      generation of a resource. It can be used to confirm that the client and
      server agree on the ordering of a resource being written.
    flagRevisions: Optional. Flag revisions used by this Unit.
    inputVariables: Optional. Output only. Indicates the current input
      variables deployed by the unit
    labels: Optional. The labels on the resource, which can be used for
      categorization. similar to Kubernetes resource labels.
    maintenance: Optional. Captures requested directives for performing future
      maintenance on the unit. This includes a request for the unit to skip
      maintenance for a period of time and remain pinned to its current
      release as well as controls for postponing maintenance scheduled in
      future.
    managementMode: Optional. Immutable. Indicates whether the Unit life cycle
      is controlled by the user or by the system. Immutable once created.
    name: Identifier. The resource name (full URI of the resource) following
      the standard naming scheme:
      "projects/{project}/locations/{location}/units/{unit}"
    ongoingOperations: Optional. Output only. List of concurrent
      UnitOperations that are operating on this Unit.
    outputVariables: Optional. Output only. Set of key/value pairs
      corresponding to output variables from execution of actuation templates.
      The variables are declared in actuation configs (e.g in helm chart or
      terraform) and the values are fetched and returned by the actuation
      engine upon completion of execution.
    pendingOperations: Optional. Output only. List of pending (wait to be
      executed) UnitOperations for this unit.
    release: Optional. Output only. The current Release object for this Unit.
    scheduledOperations: Optional. Output only. List of scheduled
      UnitOperations for this unit.
    state: Optional. Output only. Current lifecycle state of the resource
      (e.g. if it's being created or ready to use).
    systemCleanupAt: Optional. Output only. If set, indicates the time when
      the system will start removing the unit.
    systemManagedState: Optional. Output only. Indicates the system managed
      state of the unit.
    tenant: Optional. Reference to the Saas Tenant resource this unit belongs
      to. This for example informs the maintenance policies to use for
      scheduling future updates on a unit. (optional and immutable once
      created)
    uid: Output only. The unique identifier of the resource. UID is unique in
      the time and space for this resource within the scope of the service. It
      is typically generated by the server on successful creation of a
      resource and must not be changed. UID is used to uniquely identify
      resources with resource name reuses. This should be a UUID4.
    unitKind: Optional. Reference to the UnitKind this Unit belongs to.
      Immutable once set.
    updateTime: Output only. The timestamp when the resource was last updated.
      Any change to the resource made by users must refresh this value.
      Changes to a resource made by the service should refresh this value.
  c                       e Zd ZdZdZdZdZy)"Unit.ManagementModeValueValuesEnuma  Optional. Immutable. Indicates whether the Unit life cycle is
    controlled by the user or by the system. Immutable once created.

    Values:
      MANAGEMENT_MODE_UNSPECIFIED: <no description>
      MANAGEMENT_MODE_USER: Unit's lifecycle is managed by the user.
      MANAGEMENT_MODE_SYSTEM: The system will decide when to deprovision and
        delete the unit. User still can deprovision or delete the unit
        manually.
    r   r
   r   N)r   r   r   r   MANAGEMENT_MODE_UNSPECIFIEDMANAGEMENT_MODE_USERMANAGEMENT_MODE_SYSTEMr   r   r   ManagementModeValueValuesEnumr  i  s    	 #$r   r   c                   ,    e Zd ZdZdZdZdZdZdZdZ	dZ
y	)
Unit.StateValueValuesEnuma-  Optional. Output only. Current lifecycle state of the resource (e.g.
    if it's being created or ready to use).

    Values:
      UNIT_STATE_UNSPECIFIED: Unspecified state.
      UNIT_STATE_NOT_PROVISIONED: Unit is not provisioned.
      UNIT_STATE_PROVISIONING: Unit is being provisioned.
      UNIT_STATE_UPDATING: Unit is being updated. This is typically when a
        unit is being upgraded to a new release or some of the input variables
        on the Unit is being changed. Certain kinds of updates may cause the
        Unit to become unusable while the update is in progress.
      UNIT_STATE_DEPROVISIONING: Unit is being deleted.
      UNIT_STATE_READY: Unit has been provisioned and is ready for use
      UNIT_STATE_ERROR: Unit has error, when it is not ready and some error
        operation
    r   r
   r   r   r:   rY   rZ   N)r   r   r   r   UNIT_STATE_UNSPECIFIEDUNIT_STATE_NOT_PROVISIONEDUNIT_STATE_PROVISIONINGUNIT_STATE_UPDATINGUNIT_STATE_DEPROVISIONINGUNIT_STATE_READYUNIT_STATE_ERRORr   r   r   r   r  x  s3      !" !r   r   c                        e Zd ZdZdZdZdZdZy)&Unit.SystemManagedStateValueValuesEnuma  Optional. Output only. Indicates the system managed state of the unit.

    Values:
      SYSTEM_MANAGED_STATE_UNSPECIFIED: <no description>
      SYSTEM_MANAGED_STATE_ACTIVE: Unit has dependents attached.
      SYSTEM_MANAGED_STATE_INACTIVE: Unit has no dependencies attached, but
        attachment is allowed.
      SYSTEM_MANAGED_STATE_DECOMMISSIONED: Unit has no dependencies attached,
        and attachment is not allowed.
    r   r
   r   r   N)r   r   r   r    SYSTEM_MANAGED_STATE_UNSPECIFIEDSYSTEM_MANAGED_STATE_ACTIVESYSTEM_MANAGED_STATE_INACTIVE#SYSTEM_MANAGED_STATE_DECOMMISSIONEDr   r   r   !SystemManagedStateValueValuesEnumr    s!    	 ()$"#$%!*+'r   r  rA   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)Unit.AnnotationsValuerD   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)(Unit.AnnotationsValue.AdditionalPropertyrG   r
   r   NrH   r   r   r   rK   r    rL   r   rK   r
   Tr1   NrM   r   r   r   rO   r    rP   r   rO   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)Unit.LabelsValuerS   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)#Unit.LabelsValue.AdditionalPropertyrV   r
   r   NrH   r   r   r   rK   r    rL   r   rK   r
   Tr1   NrM   r   r   r   rW   r    rX   r   rW   r
   UnitConditionr   Tr1   r   UnitDependencyr:   rY   rZ   r[   r   r\   r]   r   r^   r_   r`   r   r   r   r   r  r  r  r  r           N))r   r   r   r   r   ra   r   r   r  r   rb   rN   rO   rW   r4   rc   
conditionsr   rd   dependencies
dependentsrf   rx   r   rh   maintenancerl   managementModeri   ongoingOperationsr   pendingOperationsr   scheduledOperationsr  systemCleanupAtsystemManagedStater  rj   r%   rk   r   r   r   r   r     s   Vpinn Y^^ 2,).. ,  "8!!"89Z** Z :Z6 "8!!"89ZI%% Z :Z0 '	&&'91=+%y%%oq4H*$y$$Q'*'''(8!dK,%y%%&6DI*			q	!$')''D9-)9)).!dK.!9!!-3&&	&&'<bA+&9&&'FK.			r	"$+i++B>*I**>2M/+i++B>!I!!"%'-	--b4@
)

4b
9%)I))"-/*y**+NPRS 9  $&	b!#"Y""2&($y$$R(*r   r   c                      e Zd ZdZ G d dej
                        Z G d dej
                        Z ej                  d      Z	 ej                  d      Z
 ej                  d      Z ej                  dd	      Z ej                  dd
      Zy)r  av  UnitCondition describes the status of an Unit. UnitCondition is
  individual components that contribute to an overall state.

  Enums:
    StatusValueValuesEnum: Required. Status of the condition.
    TypeValueValuesEnum: Required. Type of the condition.

  Fields:
    lastTransitionTime: Required. Last time the condition transited from one
      status to another.
    message: Required. Human readable message indicating details about the
      last transition.
    reason: Required. Brief reason for the condition's last transition.
    status: Required. Status of the condition.
    type: Required. Type of the condition.
  c                        e Zd ZdZdZdZdZdZy)#UnitCondition.StatusValueValuesEnumRequired. Status of the condition.

    Values:
      STATUS_UNSPECIFIED: Condition status is unspecified.
      STATUS_UNKNOWN: Condition is unknown.
      STATUS_TRUE: Condition is true.
      STATUS_FALSE: Condition is false.
    r   r
   r   r   Nr   r   r   r   STATUS_UNSPECIFIEDSTATUS_UNKNOWNSTATUS_TRUESTATUS_FALSEr   r   r   StatusValueValuesEnumr*         NKLr   r1  c                   $    e Zd ZdZdZdZdZdZdZy)!UnitCondition.TypeValueValuesEnuma  Required. Type of the condition.

    Values:
      TYPE_UNSPECIFIED: Condition type is unspecified.
      TYPE_READY: Condition type is ready.
      TYPE_UPDATING: Condition type is updating.
      TYPE_PROVISIONED: Condition type is provisioned.
      TYPE_OPERATION_ERROR: Condition type is operationError. True when the
        last unit operation fails with a non-ignorable error.
    r   r
   r   r   r:   N)	r   r   r   r   TYPE_UNSPECIFIED
TYPE_READYTYPE_UPDATINGTYPE_PROVISIONEDTYPE_OPERATION_ERRORr   r   r   TypeValueValuesEnumr4    s%    	 JMr   r:  r
   r   r   r:   rY   Nr   r   r   r   r   ra   r1  r:  r   lastTransitionTimemessagereasonrl   statustyper   r   r   r  r    s    "inn INN " -y,,Q/!I!!!$' 9  #&96:&			2A	6$r   r  c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)r  zSet of dependencies for this unit. Maximum 10.

  Fields:
    alias: Output only. Alias for the name of the dependency.
    unit: Output only. A reference to the Unit object.
  r
   r   N)r   r   r   r   r   r   r$   r  r   r   r   r  r  (  s-      )


"%			q	!$r   r  c                      e Zd ZdZ ej
                  d       G d dej                               Z ej
                  d       G d dej                               Z	 ej                  dd      Z ej                  d      Z ej                  d	d
      Z ej                  d      Z ej                  ddd
      Z ej                  d      Z ej                  ddd
      Z ej                  dd      Z ej                  d      Z ej                  ddd
      Z ej                  d      Z ej                  d      Z ej                  d      Zy)r   an  Definition of a Unit. Units belonging to the same UnitKind are managed
  together; for example they follow the same release model (blueprints,
  versions etc.) and are typically rolled out together.

  Messages:
    AnnotationsValue: Optional. Annotations is an unstructured key-value map
      stored with a resource that may be set by external tools to store and
      retrieve arbitrary metadata. They are not queryable and should be
      preserved when modifying objects. More info:
      https://kubernetes.io/docs/user-guide/annotations
    LabelsValue: Optional. The labels on the resource, which can be used for
      categorization. similar to Kubernetes resource labels.

  Fields:
    annotations: Optional. Annotations is an unstructured key-value map stored
      with a resource that may be set by external tools to store and retrieve
      arbitrary metadata. They are not queryable and should be preserved when
      modifying objects. More info: https://kubernetes.io/docs/user-
      guide/annotations
    createTime: Output only. The timestamp when the resource was created.
    defaultFlagRevisions: Optional. Default revisions of flags for this
      UnitKind. Newly created units will use the flag default_flag_revisions
      present at the time of creation.
    defaultRelease: Optional. A reference to the Release object to use as
      default for creating new units of this UnitKind (optional). If not
      specified, a new unit must explicitly reference which release to use for
      its creation.
    dependencies: Optional. Immutable. List of other unit kinds that this
      release will depend on. Dependencies will be automatically provisioned
      if not found. Maximum 10.
    etag: Output only. An opaque value that uniquely identifies a version or
      generation of a resource. It can be used to confirm that the client and
      server agree on the ordering of a resource being written.
    inputVariableMappings: Optional. List of inputVariables for this release
      that will either be retrieved from a dependency's outputVariables, or
      will be passed on to a dependency's inputVariables. Maximum 100.
    labels: Optional. The labels on the resource, which can be used for
      categorization. similar to Kubernetes resource labels.
    name: Identifier. The resource name (full URI of the resource) following
      the standard naming scheme:
      "projects/{project}/locations/{location}/unitKinds/{unitKind}"
    outputVariableMappings: Optional. List of outputVariables for this unit
      kind will be passed to this unit's outputVariables. Maximum 100.
    saas: Required. Immutable. A reference to the Saas that defines the
      product (managed service) that the producer wants to manage with SaaS
      Runtime. Part of the SaaS Runtime common data model. Immutable once set.
    uid: Output only. The unique identifier of the resource. UID is unique in
      the time and space for this resource within the scope of the service. It
      is typically generated by the server on successful creation of a
      resource and must not be changed. UID is used to uniquely identify
      resources with resource name reuses. This should be a UUID4.
    updateTime: Output only. The timestamp when the resource was last updated.
      Any change to the resource made by users must refresh this value.
      Changes to a resource made by the service should refresh this value.
  rA   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)UnitKind.AnnotationsValuerD   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy),UnitKind.AnnotationsValue.AdditionalPropertyrG   r
   r   NrH   r   r   r   rK   rF  |  rL   r   rK   r
   Tr1   NrM   r   r   r   rO   rD  m  rP   r   rO   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)UnitKind.LabelsValuerS   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)'UnitKind.LabelsValue.AdditionalPropertyrV   r
   r   NrH   r   r   r   rK   rJ    rL   r   rK   r
   Tr1   NrM   r   r   r   rW   rH    rX   r   rW   r
   r   r   Tr1   r:   r#   rY   rZ   VariableMappingr[   r\   r]   r^   r_   r`   r   N)r   r   r   r   r   rb   r   rN   rO   rW   r4   rc   r   rd   defaultFlagRevisionsdefaultReleaser  rf   inputVariableMappingsrh   ri   outputVariableMappingsr   rj   rk   r   r   r   r   r   4  sr   6p "8!!"89Z** Z :Z6 "8!!"89ZI%% Z :Z0 '	&&'91=+$y$$Q'*...q4@(9((+.'''a$G,			q	!$0)001BAPTU!9!!-3&			q	!$19112CRRVW			r	"$	b!#$y$$R(*r   r   c                      e Zd ZdZ G d dej
                        Z G d dej
                        Z ej                  d       G d dej                               Z ej                  d       G d	 d
ej                               Z ej                  dd      Z ej                  d      Z ej                  ddd      Z ej$                  d      Z ej                  dd      Z ej$                  d      Z ej,                  dd      Z ej$                  d      Z ej                  dd      Z ej                  d
d      Z ej$                  d      Z ej$                  d      Z ej                  dd      Z ej$                  d      Z ej                  dd       Z ej,                  dd!      Z  ej$                  d"      Z! ej$                  d#      Z" ej$                  d$      Z# ej                  d%d&      Z$y')(r   a  UnitOperation encapsulates the intent of changing/interacting with the
  service component represented by the specific Unit. Multiple UnitOperations
  can be created (requested) and scheduled in the future, however only one
  will be allowed to execute at a time (that can change in the future for non-
  mutating operations). UnitOperations allow different actors interacting with
  the same unit to focus only on the change they have requested. This is a
  base object that contains the common fields in all unit operations. Next: 19

  Enums:
    ErrorCategoryValueValuesEnum: Optional. Output only.
      UnitOperationErrorCategory describe the error category.
    StateValueValuesEnum: Optional. Output only. UnitOperationState describes
      the current state of the unit operation.

  Messages:
    AnnotationsValue: Optional. Annotations is an unstructured key-value map
      stored with a resource that may be set by external tools to store and
      retrieve arbitrary metadata. They are not queryable and should be
      preserved when modifying objects. More info:
      https://kubernetes.io/docs/user-guide/annotations
    LabelsValue: Optional. The labels on the resource, which can be used for
      categorization. similar to Kubernetes resource labels.

  Fields:
    annotations: Optional. Annotations is an unstructured key-value map stored
      with a resource that may be set by external tools to store and retrieve
      arbitrary metadata. They are not queryable and should be preserved when
      modifying objects. More info: https://kubernetes.io/docs/user-
      guide/annotations
    cancel: Optional. When true, attempt to cancel the operation. Cancellation
      may fail if the operation is already executing. (Optional)
    conditions: Optional. Output only. A set of conditions which indicate the
      various conditions this resource can have.
    createTime: Output only. The timestamp when the resource was created.
    deprovision: A Deprovision attribute.
    engineState: Optional. Output only. The engine state for on-going
      deployment engine operation(s). This field is opaque for external usage.
    errorCategory: Optional. Output only. UnitOperationErrorCategory describe
      the error category.
    etag: Output only. An opaque value that uniquely identifies a version or
      generation of a resource. It can be used to confirm that the client and
      server agree on the ordering of a resource being written.
    flagUpdate: A FlagUpdate attribute.
    labels: Optional. The labels on the resource, which can be used for
      categorization. similar to Kubernetes resource labels.
    name: Identifier. The resource name (full URI of the resource) following
      the standard naming scheme:
      "projects/{project}/locations/{location}/unitOperations/{unitOperation}"
    parentUnitOperation: Optional. Reference to parent resource:
      UnitOperation. If an operation needs to create other operations as part
      of its workflow, each of the child operations should have this field set
      to the parent. This can be used for tracing. (Optional)
    provision: A Provision attribute.
    rollout: Optional. Specifies which rollout created this Unit Operation.
      This cannot be modified and is used for filtering purposes only. If a
      dependent unit and unit operation are created as part of another unit
      operation, they will use the same rolloutId.
    schedule: Optional. When to schedule this operation.
    state: Optional. Output only. UnitOperationState describes the current
      state of the unit operation.
    uid: Output only. The unique identifier of the resource. UID is unique in
      the time and space for this resource within the scope of the service. It
      is typically generated by the server on successful creation of a
      resource and must not be changed. UID is used to uniquely identify
      resources with resource name reuses. This should be a UUID4.
    unit: Required. Immutable. The Unit a given UnitOperation will act upon.
    updateTime: Output only. The timestamp when the resource was last updated.
      Any change to the resource made by users must refresh this value.
      Changes to a resource made by the service should refresh this value.
    upgrade: A Upgrade attribute.
  c                   (    e Zd ZdZdZdZdZdZdZdZ	y)	*UnitOperation.ErrorCategoryValueValuesEnumaB  Optional. Output only. UnitOperationErrorCategory describe the error
    category.

    Values:
      UNIT_OPERATION_ERROR_CATEGORY_UNSPECIFIED: Unit operation error category
        is unspecified
      NOT_APPLICABLE: Unit operation error category is not applicable, or it
        is not an error
      FATAL: Unit operation error category is fatal
      RETRIABLE: Unit operation error category is retriable
      IGNORABLE: Unit operation error category is ignorable
      STANDARD: Unit operation error category is standard, counts towards
        Rollout error budget
    r   r
   r   r   r:   rY   N)
r   r   r   r   )UNIT_OPERATION_ERROR_CATEGORY_UNSPECIFIEDNOT_APPLICABLEFATAL	RETRIABLE	IGNORABLESTANDARDr   r   r   ErrorCategoryValueValuesEnumrR    s(     12-NEIIHr   rY  c                   ,    e Zd ZdZdZdZdZdZdZdZ	dZ
y	)
"UnitOperation.StateValueValuesEnumav  Optional. Output only. UnitOperationState describes the current state
    of the unit operation.

    Values:
      UNIT_OPERATION_STATE_UNKNOWN: <no description>
      UNIT_OPERATION_STATE_PENDING: Unit operation is accepted but not ready
        to run.
      UNIT_OPERATION_STATE_SCHEDULED: Unit operation is accepted and
        scheduled.
      UNIT_OPERATION_STATE_RUNNING: Unit operation is running.
      UNIT_OPERATION_STATE_SUCCEEDED: Unit operation has completed
        successfully.
      UNIT_OPERATION_STATE_FAILED: Unit operation has failed.
      UNIT_OPERATION_STATE_CANCELLED: Unit operation was cancelled.
    r   r
   r   r   r:   rY   rZ   N)r   r   r   r   UNIT_OPERATION_STATE_UNKNOWNUNIT_OPERATION_STATE_PENDINGUNIT_OPERATION_STATE_SCHEDULEDUNIT_OPERATION_STATE_RUNNINGUNIT_OPERATION_STATE_SUCCEEDEDUNIT_OPERATION_STATE_FAILEDUNIT_OPERATION_STATE_CANCELLEDr   r   r   r   r[    s3     $% #$ %&"#$ %&""#%&"r   r   rA   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)UnitOperation.AnnotationsValuerD   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)1UnitOperation.AnnotationsValue.AdditionalPropertyrG   r
   r   NrH   r   r   r   rK   rf  7  rL   r   rK   r
   Tr1   NrM   r   r   r   rO   rd  (  rP   r   rO   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)UnitOperation.LabelsValuerS   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy),UnitOperation.LabelsValue.AdditionalPropertyrV   r
   r   NrH   r   r   r   rK   rj  P  rL   r   rK   r
   Tr1   NrM   r   r   r   rW   rh  D  rX   r   rW   r
   r   UnitOperationConditionr   Tr1   r:   r'   rY   rZ   r[   r\   r   r]   r^   r_   r`   r   r   r   r  r   r   r  r  r  Upgrader  N)%r   r   r   r   r   ra   rY  r   r   rb   rN   rO   rW   r4   rc   r2  cancelr  r   rd   deprovisionengineStaterl   errorCategoryrf   
flagUpdaterh   ri   parentUnitOperation	provisionr  scheduler  rj   r  rk   upgrader   r   r   r   r     s   FPY^^ ,'Y^^ '0 "8!!"89Z** Z :Z6 "8!!"89ZI%% Z :Z0 '	&&'91=+!9!!!$&%y%%&>DQ*$y$$Q'*&	&&}a8+%	%%a(+%)%%&DaH-			q	!$%y%%lA6*!9!!-4&			r	"$-	--b1$i$$["5)!I!!"%'#Y##J3(
)

4b
9%	b!#			r	"$$y$$R(*"I""9b1'r   r   c                      e Zd ZdZ G d dej
                        Z G d dej
                        Z ej                  d      Z	 ej                  d      Z
 ej                  d      Z ej                  dd	      Z ej                  dd
      Zy)rk  a  UnitOperationCondition describes the status of an Unit Operation.
  UnitOperationCondition is individual components that contribute to an
  overall state.

  Enums:
    StatusValueValuesEnum: Required. Status of the condition.
    TypeValueValuesEnum: Required. Type of the condition.

  Fields:
    lastTransitionTime: Required. Last time the condition transited from one
      status to another.
    message: Required. Human readable message indicating details about the
      last transition.
    reason: Required. Brief reason for the condition's last transition.
    status: Required. Status of the condition.
    type: Required. Type of the condition.
  c                        e Zd ZdZdZdZdZdZy),UnitOperationCondition.StatusValueValuesEnumr+  r   r
   r   r   Nr,  r   r   r   r1  rx    r2  r   r1  c                   $    e Zd ZdZdZdZdZdZdZy)*UnitOperationCondition.TypeValueValuesEnuma1  Required. Type of the condition.

    Values:
      TYPE_UNSPECIFIED: Condition type is unspecified.
      TYPE_SCHEDULED: Condition type is scheduled.
      TYPE_RUNNING: Condition type is running.
      TYPE_SUCCEEDED: Condition type is succeeded.
      TYPE_CANCELLED: Condition type is cancelled.
    r   r
   r   r   r:   N)	r   r   r   r   r5  TYPE_SCHEDULEDTYPE_RUNNINGTYPE_SUCCEEDEDTYPE_CANCELLEDr   r   r   r:  rz    s#     NLNNr   r:  r
   r   r   r:   rY   Nr;  r   r   r   rk  rk  s  s    $inn INN   -y,,Q/!I!!!$' 9  #&96:&			2A	6$r   rk  c                       e Zd ZdZ G d dej
                        Z ej                  dd      Z ej                  d      Z
 ej                  d      Zy)r   a  UnitVariable describes a parameter for a Unit.

  Enums:
    TypeValueValuesEnum: Optional. Immutable. Name of a supported variable
      type. Supported types are string, int, bool.

  Fields:
    type: Optional. Immutable. Name of a supported variable type. Supported
      types are string, int, bool.
    value: Optional. String encoded value for the variable.
    variable: Required. Immutable. Name of the variable from actuation
      configs.
  c                        e Zd ZdZdZdZdZdZy) UnitVariable.TypeValueValuesEnuma  Optional. Immutable. Name of a supported variable type. Supported
    types are string, int, bool.

    Values:
      TYPE_UNSPECIFIED: Variable type is unspecified.
      STRING: Variable type is string.
      INT: Variable type is int.
      BOOL: Variable type is bool.
    r   r
   r   r   N)r   r   r   r   r5  STRINGINTBOOLr   r   r   r:  r    s     F
CDr   r:  r
   r   r   N)r   r   r   r   r   ra   r:  rl   r@  r   rJ   variabler   r   r   r   r     sR    INN  
		2A	6$
)


"%"Y""1%(r   r   c                   ^    e Zd ZdZ ej
                  ddd      Z ej                  d      Zy)rl  a{  Upgrade is the unit operation that upgrades a provisioned unit, which
  may also include the underlying resources represented by a Unit. Can only
  execute if the Unit is currently provisioned.

  Fields:
    inputVariables: Optional. Set of input variables. Maximum 100. (optional)
    release: Optional. Reference to the Release object to use for the Unit.
      (optional).
  r   r
   Tr1   r   Nr   r   r   r   rl  rl    r   r   rl  c                       e Zd ZdZ ej
                  dd      Z ej
                  dd      Z ej                  d      Z	y)rK  a?  Mapping of input variables to their respective output variable for
  depedenencies

  Fields:
    from_: Optional. Output variables which will get their values from
      dependencies
    to: Optional. Input variables whose values will be passed on to
      dependencies.
    variable: Required. name of the variable
  r   r
   r  r   r   N)
r   r   r   r   r   r4   from_tor   r  r   r   r   rK  rK    sC    	 !)
 
 
2%yk1-""Y""1%(r   rK  c                       e Zd ZdZ ej
                  d      Z ej                  d      Z ej                  d      Z
 ej                  d      Z ej                  d      Zy)r   aC  Variant is an identifier for a value (name assigned to a value).

  Fields:
    boolValue: Optional. Boolean flag value.
    doubleValue: Optional. Double flag value.
    intValue: Optional. Integer flag value.
    name: Required. Name of the variant. Max length: 128 bytes.
    stringValue: Optional. String flag value.
  r
   r   r   r:   rY   N)r   r   r   r   r   r2  	boolValue
FloatFielddoubleValuer   intValuer   ri   stringValuer   r   r   r   r     sc     %i$$Q')$	$$Q'+#Y##A&(			q	!$%	%%a(+r   r   r  fromr  z$.xgafvr  1r  2N)yr   
__future__r   apitools.base.protorpcliter   r   apitools.base.pyr   r   r    rN   r	   r   r#   r'   r*   r,   r0   r7   ro   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>  rF  rJ  rM  rU  rX  r\  r^  r`  rb  rd  rg  ri  rk  rm  ro  rq  rt  rw  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   rk  r   rl  rK  r   AddCustomJsonFieldMappingAddCustomJsonEnumMappingr  r   r   r   <module>r     s\   ' < % ( #	!! #%	!! %(&"" &)## I Q)## Q 	AY&& 	ABB9 BBJj))## j)Zg)9$$ g)T)"" )
,)## 
,M")"3"3 M"`8y00 8 8	 1 1 8 8	)) 8 
+I-- 
+89,, 8 8y00 8 89,, 8 8y(( 8 8)++ 8 8I-- 8 8!2!2 8 8	)) 8 "y   "-)++ - %	!! %t)i t)n
D)++ 
D{)i {)|)BY&& )BXM\)## M\`L9$$ L
4Y.. 
4c(9 c(L+	@Q@Q +<+	@Q@Q +D1Y=N=N 13i>O>O 3&!+y?P?P !+H+ARAR +<+ARAR +D1i>O>O 13y?P?P 3&!+	@Q@Q !+H+9J9J +<+9J9J +D1i6G6G 13y7H7H 3&!+	8I8I !+H11B1B 1')2C2C '0+I<M<M +<+I<M<M +D19J9J 13):K:K 3&!+9;L;L !+H+	@Q@Q +<+	@Q@Q +D1Y=N=N 13i>O>O 3&!+y?P?P !+H+I<M<M +<+I<M<M +D19J9J 13):K:K 3&!+9;L;L !+H+	8I8I +<+	8I8I +D1Y5F5F 13i6G6G 3&!+y7H7H !+H+9;L;L +<+9;L;L +D1	8I8I 139J9J 3&!+):K:K !+H+Y=N=N +<+Y=N=N +D1):K:K 139;L;L 3&!+I<M<M !+H+)BSBS +<+)BSBS +D1y?P?P 13	@Q@Q 3&!+ARAR !+H+9J9J +<+9J9J +D1i6G6G 13y7H7H 3&!+	8I8I !+H'y   '<.i// <.~o(Y o(d+	!! + ])9 ])@57I%% 57p	"Y&& 	"z)y   z)z2I%% 2D57Y.. 57p &9$$  &F%i %&i'' &")i )$ # " "Wf& " " "Z4 ! ! !114> ! ! !114>r   