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

Cloud Spanner is a managed, mission-critical, globally consistent and scalable
relational database service.
    )absolute_import)messages)encoding)extra_typesspannerc                       \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " SS5      r\R                  " S5      r\R                  " S5      rS	rg
)AdaptMessageRequest   a  Message sent by the client to the adapter.

Messages:
  AttachmentsValue: Optional. Opaque request state passed by the client to
    the server.

Fields:
  attachments: Optional. Opaque request state passed by the client to the
    server.
  payload: Optional. Uninterpreted bytes from the underlying wire protocol.
  protocol: Required. Identifier for the underlying wire protocol.
additionalPropertiesc                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
$AdaptMessageRequest.AttachmentsValue    zOptional. Opaque request state passed by the client to the server.

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

Fields:
  additionalProperties: Additional properties of type AttachmentsValue
c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)7AdaptMessageRequest.AttachmentsValue.AdditionalProperty,   zAn additional property for a AttachmentsValue object.

Fields:
  key: Name of the additional property.
  value: A string attribute.
       N
__name__
__module____qualname____firstlineno____doc__	_messagesStringFieldkeyvalue__static_attributes__r       Klib/googlecloudsdk/generated_clients/apis/spanner/v1/spanner_v1_messages.pyAdditionalPropertyr   ,   )    
 !!!$c##A&er    r"   r   Trepeatedr   Nr   r   r   r   r   r   Messager"   MessageFieldr   r   r   r    r!   AttachmentsValuer       2    	'Y.. 	' %112FTXYr    r)   r   r      r   N)r   r   r   r   r   r   MapUnrecognizedFieldsr   r'   r)   r(   attachments
BytesFieldpayloadr   protocolr   r   r    r!   r	   r	      sl     !!"89Z** Z :Z0 &&'91=+  #'""1%(r    r	   c                       \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " S5      r\R                  " S5      r\R                  " SS5      rS	rg
)AdaptMessageResponse>   a  Message sent by the adapter to the client.

Messages:
  StateUpdatesValue: Optional. Opaque state updates to be applied by the
    client.

Fields:
  last: Optional. Indicates whether this is the last AdaptMessageResponse in
    the stream. This field may be optionally set by the server. Clients
    should not rely on this field being set in all cases.
  payload: Optional. Uninterpreted bytes from the underlying wire protocol.
  stateUpdates: Optional. Opaque state updates to be applied by the client.
r   c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
&AdaptMessageResponse.StateUpdatesValueM   zOptional. Opaque state updates to be applied by the client.

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

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

Fields:
  key: Name of the additional property.
  value: A string attribute.
r   r   r   Nr   r   r    r!   r"   r8   Y   r#   r    r"   r   Tr$   r   Nr&   r   r    r!   StateUpdatesValuer5   M   r*   r    r:   r   r   r+   r   N)r   r   r   r   r   r   r,   r   r'   r:   BooleanFieldlastr.   r/   r(   stateUpdatesr   r   r    r!   r2   r2   >   sl     !!"89Z)++ Z :Z0 
			"$  #'''(;Q?,r    r2   c                   <    \ rS rSrSr\R                  " S5      rSrg)AdapterSessionk   zA session in the Cloud Spanner Adapter API.

Fields:
  name: Identifier. The name of the session. This is always system-assigned.
r   r   N	r   r   r   r   r   r   r   namer   r   r    r!   r?   r?   k   s     
		q	!$r    r?   c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
AddSplitPointsRequestu   a  The request for AddSplitPoints.

Fields:
  initiator: Optional. A user-supplied tag associated with the split points.
    For example, "initial_data_load", "special_event_1". Defaults to
    "CloudAddSplitPointsAPI" if not specified. The length of the tag must
    not exceed 50 characters, or else it is trimmed. Only valid UTF8
    characters are allowed.
  splitPoints: Required. The split points to add.
r   SplitPointsr   Tr$   r   N)r   r   r   r   r   r   r   	initiatorr(   splitPointsr   r   r    r!   rD   rD   u   s-    	 ##A&)&&}a$G+r    rD   c                       \ rS rSrSrSrg)AddSplitPointsResponse   z The response for AddSplitPoints.r   Nr   r   r   r   r   r   r   r    r!   rJ   rJ      s    )r    rJ   c                   d    \ rS rSrSr\R                  " SS5      r\R                  " SS5      rSr	g)	AsymmetricAutoscalingOption   ar  AsymmetricAutoscalingOption specifies the scaling of replicas identified
by the given selection.

Fields:
  overrides: Optional. Overrides applied to the top-level autoscaling
    configuration for the selected replicas.
  replicaSelection: Required. Selects the replicas to which this
    AsymmetricAutoscalingOption applies. Only read-only replicas are
    supported.
AutoscalingConfigOverridesr   InstanceReplicaSelectionr   r   N)
r   r   r   r   r   r   r(   	overridesreplicaSelectionr   r   r    r!   rN   rN      s0    	 $$%A1E)++,FJr    rN   c                       \ rS rSrSr\R                  " SSSS9r\R                  " SS5      r\R                  " S	S
5      r	\R                  " S5      rSrg)AutoscalingConfig   a  Autoscaling configuration for an instance.

Fields:
  asymmetricAutoscalingOptions: Optional. Optional asymmetric autoscaling
    options. Replicas matching the replica selection criteria will be
    autoscaled independently from other replicas. The autoscaler will scale
    the replicas based on the utilization of replicas identified by the
    replica selection. Replica selections should not overlap with each
    other. Other replicas (those do not match any replica selection) will be
    autoscaled together and will have the same compute capacity allocated to
    them.
  autoscalingLimits: Required. Autoscaling limits for an instance.
  autoscalingTargets: Required. The autoscaling targets for an instance.
  disableDownscaling: Optional. If disable_downscaling is true, the
    autoscaler will not scale down the instance; it will only be able to
    scale up. This setting will be applied to all replicas under the
    instance.
rN   r   Tr$   AutoscalingLimitsr   AutoscalingTargetsr+      r   N)r   r   r   r   r   r   r(   asymmetricAutoscalingOptionsautoscalingLimitsautoscalingTargetsr;   disableDownscalingr   r   r    r!   rU   rU      sZ    & "+!7!78UWXcg!h,,-@!D --.BAF --a0r    rU   c                      \ rS rSrSr\R                  " SS5      r\R                  " S\R                  R                  S9r\R                  " S\R                  R                  S9r\R                  " S5      r\R                  " S	5      rS
rg)rP      ag	  Overrides the top-level autoscaling configuration for the replicas
identified by `replica_selection`. All fields in this message are optional.
Any unspecified fields will use the corresponding values from the top-level
autoscaling configuration.

Fields:
  autoscalingLimits: Optional. If specified, overrides the min/max limit in
    the top-level autoscaling configuration for the selected replicas.
  autoscalingTargetHighPriorityCpuUtilizationPercent: Optional. If
    specified, overrides the autoscaling target
    high_priority_cpu_utilization_percent in the top-level autoscaling
    configuration for the selected replicas.
  autoscalingTargetTotalCpuUtilizationPercent: Optional. If specified,
    overrides the autoscaling target `total_cpu_utilization_percent` in the
    top-level autoscaling configuration for the selected replicas.
  disableHighPriorityCpuAutoscaling: Optional. If true, disables high
    priority CPU autoscaling for the selected replicas and ignores
    high_priority_cpu_utilization_percent in the top-level autoscaling
    configuration. When setting this field to true, setting
    autoscaling_target_high_priority_cpu_utilization_percent field to a non-
    zero value for the same replica is not supported. If false, the
    autoscaling_target_high_priority_cpu_utilization_percent field in the
    replica will be used if set to a non-zero value. Otherwise, the
    high_priority_cpu_utilization_percent field in the top-level autoscaling
    configuration will be used. Setting both
    disable_high_priority_cpu_autoscaling and disable_total_cpu_autoscaling
    to true for the same replica is not supported.
  disableTotalCpuAutoscaling: Optional. If true, disables total CPU
    autoscaling for the selected replicas and ignores
    total_cpu_utilization_percent in the top-level autoscaling
    configuration. When setting this field to true, setting
    autoscaling_target_total_cpu_utilization_percent field to a non-zero
    value for the same replica is not supported. If false, the
    autoscaling_target_total_cpu_utilization_percent field in the replica
    will be used if set to a non-zero value. Otherwise, the
    total_cpu_utilization_percent field in the top-level autoscaling
    configuration will be used. Setting both
    disable_high_priority_cpu_autoscaling and disable_total_cpu_autoscaling
    to true for the same replica is not supported.
rW   r   r   variantr+   rY      r   N)r   r   r   r   r   r   r(   r[   IntegerFieldVariantINT322autoscalingTargetHighPriorityCpuUtilizationPercent+autoscalingTargetTotalCpuUtilizationPercentr;   !disableHighPriorityCpuAutoscalingdisableTotalCpuAutoscalingr   r   r    r!   rP   rP      s    'R  ,,-@!D7@7M7MaYbYjYjYpYp7q4090F0FqR[RcRcRiRi0j-&/&<&<Q&?#(55a8r    rP   c                   @   \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " S\R                  R                  S9r
\R                  " S\R                  R                  S9r\R                  " S\R                  R                  S9rSrg	)
rW      a  The autoscaling limits for the instance. Users can define the minimum
and maximum compute capacity allocated to the instance, and the autoscaler
will only scale within that range. Users can either use nodes or processing
units to specify the limits, but should use the same unit to set both the
min_limit and max_limit.

Fields:
  maxNodes: Maximum number of nodes allocated to the instance. If set, this
    number should be greater than or equal to min_nodes.
  maxProcessingUnits: Maximum number of processing units allocated to the
    instance. If set, this number should be multiples of 1000 and be greater
    than or equal to min_processing_units.
  minNodes: Minimum number of nodes allocated to the instance. If set, this
    number should be greater than or equal to 1.
  minProcessingUnits: Minimum number of processing units allocated to the
    instance. If set, this number should be multiples of 1000.
r   r`   r   r+   rY   r   N)r   r   r   r   r   r   rc   rd   re   maxNodesmaxProcessingUnitsminNodesminProcessingUnitsr   r   r    r!   rW   rW      s    $ ##Ay/@/@/F/FG( --a9J9J9P9PQ##Ay/@/@/F/FG( --a9J9J9P9PQr    rW   c                       \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " S\R                  R                  S9r
\R                  " S\R                  R                  S9rSrg)	rX      a  The autoscaling targets for an instance.

Fields:
  highPriorityCpuUtilizationPercent: Required. The target high priority cpu
    utilization percentage that the autoscaler should be trying to achieve
    for the instance. This number is on a scale from 0 (no utilization) to
    100 (full utilization). The valid range is [10, 90] inclusive.
  storageUtilizationPercent: Required. The target storage utilization
    percentage that the autoscaler should be trying to achieve for the
    instance. This number is on a scale from 0 (no utilization) to 100 (full
    utilization). The valid range is [10, 99] inclusive.
  totalCpuUtilizationPercent: Optional. The target total CPU utilization
    percentage that the autoscaler should be trying to achieve for the
    instance. This number is on a scale from 0 (no utilization) to 100 (full
    utilization). The valid range is [10, 90] inclusive. If not specified or
    set to 0, the autoscaler skips scaling based on total CPU utilization.
    If both `high_priority_cpu_utilization_percent` and
    `total_cpu_utilization_percent` are specified, the autoscaler provisions
    the larger of the two required compute capacities to satisfy both
    targets.
r   r`   r   r+   r   N)r   r   r   r   r   r   rc   rd   re   !highPriorityCpuUtilizationPercentstorageUtilizationPercenttotalCpuUtilizationPercentr   r   r    r!   rX   rX      sf    , '0&<&<Q	HYHYH_H_&`#'44Q	@Q@Q@W@WX(55aARARAXAXYr    rX   c                      \ rS rSrSr " S S\R                  5      r " S S\R                  5      r\R                  " SSS	9r
\R                  " S
5      r\R                  " S5      r\R                  " SS5      r\R                  " SS5      r\R                  " SSSS	9r\R$                  " S5      r\R                  " S5      r\R$                  " S5      r\R                  " S5      r\R                  " SSSS	9r\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                  " SSS	9r\R                  " SSS	9r\R$                  " S5      r\R                  " SS5      r\R                  " S5      rSr g) Backupi  a  A backup of a Cloud Spanner database.

Enums:
  DatabaseDialectValueValuesEnum: Output only. The database dialect
    information for the backup.
  StateValueValuesEnum: Output only. The current state of the backup.

Fields:
  backupSchedules: Output only. List of backup schedule URIs that are
    associated with creating this backup. This is only applicable for
    scheduled backups, and is empty for on-demand backups. To optimize for
    storage, whenever possible, multiple schedules are collapsed together to
    create one backup. In such cases, this field captures the list of all
    backup schedule URIs that are associated with creating this backup. If
    collapsing is not done, then this field captures the single backup
    schedule URI associated with creating this backup.
  createTime: Output only. The time the CreateBackup request is received. If
    the request does not specify `version_time`, the `version_time` of the
    backup will be equivalent to the `create_time`.
  database: Required for the CreateBackup operation. Name of the database
    from which this backup was created. This needs to be in the same
    instance as the backup. Values are of the form
    `projects//instances//databases/`.
  databaseDialect: Output only. The database dialect information for the
    backup.
  encryptionInfo: Output only. The encryption information for the backup.
  encryptionInformation: Output only. The encryption information for the
    backup, whether it is protected by one or more KMS keys. The information
    includes all Cloud KMS key versions used to encrypt the backup. The
    `encryption_status` field inside of each `EncryptionInfo` is not
    populated. At least one of the key versions must be available for the
    backup to be restored. If a key version is revoked in the middle of a
    restore, the restore behavior is undefined.
  exclusiveSizeBytes: Output only. For a backup in an incremental backup
    chain, this is the storage space needed to keep the data that has
    changed since the previous backup. For all other backups, this is always
    the size of the backup. This value may change if backups on the same
    chain get deleted or expired. This field can be used to calculate the
    total storage space used by a set of backups. For example, the total
    space used by all backups of a database can be computed by summing up
    this field.
  expireTime: Required for the CreateBackup operation. The expiration time
    of the backup, with microseconds granularity that must be at least 6
    hours and at most 366 days from the time the CreateBackup request is
    processed. Once the `expire_time` has passed, the backup is eligible to
    be automatically deleted by Cloud Spanner to free the resources used by
    the backup.
  freeableSizeBytes: Output only. The number of bytes that will be freed by
    deleting this backup. This value will be zero if, for example, this
    backup is part of an incremental backup chain and younger backups in the
    chain require that we keep its data. For backups not in an incremental
    backup chain, this is always the size of the backup. This value may
    change if backups on the same chain get created, deleted or expired.
  incrementalBackupChainId: Output only. Populated only for backups in an
    incremental backup chain. Backups share the same chain id if and only if
    they belong to the same incremental backup chain. Use this field to
    determine which backups are part of the same incremental backup chain.
    The ordering of backups in the chain can be determined by ordering the
    backup `version_time`.
  instancePartitions: Output only. The instance partition storing the
    backup. This is the same as the list of the instance partitions that the
    database recorded at the backup's `version_time`.
  maxExpireTime: Output only. The max allowed expiration time of the backup,
    with microseconds granularity. A backup's expiration time can be
    configured in multiple APIs: CreateBackup, UpdateBackup, CopyBackup.
    When updating or copying an existing backup, the expiration time
    specified must be less than `Backup.max_expire_time`.
  name: Output only for the CreateBackup operation. Required for the
    UpdateBackup operation. A globally unique identifier for the backup
    which cannot be changed. Values are of the form
    `projects//instances//backups/a-z*[a-z0-9]` The final segment of the
    name must be between 2 and 60 characters in length. The backup is stored
    in the location(s) specified in the instance configuration of the
    instance containing the backup, identified by the prefix of the backup
    name of the form `projects//instances/`.
  oldestVersionTime: Output only. Data deleted at a time older than this is
    guaranteed not to be retained in order to support this backup. For a
    backup in an incremental backup chain, this is the version time of the
    oldest backup that exists or ever existed in the chain. For all other
    backups, this is the version time of the backup. This field can be used
    to understand what data is being retained by the backup system.
  referencingBackups: Output only. The names of the destination backups
    being created by copying this source backup. The backup names are of the
    form `projects//instances//backups/`. Referencing backups may exist in
    different instances. The existence of any referencing backup prevents
    the backup from being deleted. When the copy operation is done (either
    successfully completed or cancelled or the destination backup is
    deleted), the reference to the backup is removed.
  referencingDatabases: Output only. The names of the restored databases
    that reference the backup. The database names are of the form
    `projects//instances//databases/`. Referencing databases may exist in
    different instances. The existence of any referencing database prevents
    the backup from being deleted. When a restored database from the backup
    enters the `READY` state, the reference to the backup is removed.
  sizeBytes: Output only. Size of the backup in bytes. For a backup in an
    incremental backup chain, this is the sum of the `exclusive_size_bytes`
    of itself and all older backups in the chain.
  state: Output only. The current state of the backup.
  versionTime: The backup will contain an externally consistent copy of the
    database at the timestamp specified by `version_time`. If `version_time`
    is not specified, the system will set `version_time` to the
    `create_time` of the backup.
c                   $    \ rS rSrSrSrSrSrSrg)%Backup.DatabaseDialectValueValuesEnumi  a  Output only. The database dialect information for the backup.

Values:
  DATABASE_DIALECT_UNSPECIFIED: Default value. This value will create a
    database with the GOOGLE_STANDARD_SQL dialect.
  GOOGLE_STANDARD_SQL: GoogleSQL supported SQL.
  POSTGRESQL: PostgreSQL supported SQL.
r   r   r   r   N	r   r   r   r   r   DATABASE_DIALECT_UNSPECIFIEDGOOGLE_STANDARD_SQL
POSTGRESQLr   r   r    r!   DatabaseDialectValueValuesEnumrx          $% Jr    r}   c                   $    \ rS rSrSrSrSrSrSrg)Backup.StateValueValuesEnumi  a  Output only. The current state of the backup.

Values:
  STATE_UNSPECIFIED: Not specified.
  CREATING: The pending backup is still being created. Operations on the
    backup may fail with `FAILED_PRECONDITION` in this state.
  READY: The backup is complete and ready for use.
r   r   r   r   N	r   r   r   r   r   STATE_UNSPECIFIEDCREATINGREADYr   r   r    r!   StateValueValuesEnumr     s     HEr    r   r   Tr$   r   r+   rY   EncryptionInforb            	   
   BackupInstancePartition                     r
      r   N)!r   r   r   r   r   r   Enumr}   r   r   backupSchedules
createTimedatabase	EnumFielddatabaseDialectr(   encryptionInfoencryptionInformationrc   exclusiveSizeBytes
expireTimefreeableSizeBytesincrementalBackupChainIdinstancePartitionsmaxExpireTimerB   oldestVersionTimereferencingBackupsreferencingDatabases	sizeBytesstateversionTimer   r   r    r!   rv   rv     s}   fPy~~ Y^^  ))!d;/$$Q'*""1%(''(H!L/))*:A>.#001A1tT --a0$$Q'*,,Q/&2226 --.GVZ[''+-			r	"$++B/ ,,R$?"..rDA$$R()


4b
9%%%b)+r    rv   c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S5      r	\R                  " S5      r
Srg)	
BackupInfoi  a  Information about a backup.

Fields:
  backup: Name of the backup.
  createTime: The time the CreateBackup request was received.
  sourceDatabase: Name of the database the backup was created from.
  versionTime: The backup contains an externally consistent copy of
    `source_database` at the timestamp specified by `version_time`. If the
    CreateBackup request did not specify `version_time`, the `version_time`
    of the backup is equivalent to the `create_time`.
r   r   r+   rY   r   N)r   r   r   r   r   r   r   backupr   sourceDatabaser   r   r   r    r!   r   r     sI    
   #&$$Q'*((+.%%a(+r    r   c                   <    \ rS rSrSr\R                  " S5      rSrg)r   i  zInstance partition information for the backup.

Fields:
  instancePartition: A unique identifier for the instance partition. Values
    are of the form `projects//instances//instancePartitions/`
r   r   N)	r   r   r   r   r   r   r   instancePartitionr   r   r    r!   r   r     s      ++A.r    r   c                      \ rS rSrSr\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r	\R                  " S	5      r\R                  " S
5      r\R                  " SS5      r\R                  " S5      rSrg)BackupSchedulei  a5  BackupSchedule expresses the automated backup creation specification for
a Spanner database.

Fields:
  encryptionConfig: Optional. The encryption configuration that is used to
    encrypt the backup. If this field is not specified, the backup uses the
    same encryption configuration as the database.
  fullBackupSpec: The schedule creates only full backups.
  incrementalBackupSpec: The schedule creates incremental backup chains.
  name: Identifier. Output only for the CreateBackupSchedule operation.
    Required for the UpdateBackupSchedule operation. A globally unique
    identifier for the backup schedule which cannot be changed. Values are
    of the form
    `projects//instances//databases//backupSchedules/a-z*[a-z0-9]` The final
    segment of the name must be between 2 and 60 characters in length.
  retentionDuration: Optional. The retention duration of a backup that must
    be at least 6 hours and at most 366 days. The backup is eligible to be
    automatically deleted once the retention period has elapsed.
  spec: Optional. The schedule specification based on which the backup
    creations are triggered.
  updateTime: Output only. The timestamp at which the schedule was last
    updated. If the schedule has never been updated, this field contains the
    timestamp when the schedule was first created.
CreateBackupEncryptionConfigr   FullBackupSpecr   IncrementalBackupSpecr+   rY   rb   BackupScheduleSpecr   r   r   N)r   r   r   r   r   r   r(   encryptionConfigfullBackupSpecincrementalBackupSpecr   rB   retentionDurationspec
updateTimer   r   r    r!   r   r     s    2 ++,JAN))*:A>.#001H!L			q	!$++A.			 4a	8$$$Q'*r    r   c                   >    \ rS rSrSr\R                  " SS5      rSrg)r   i  zgDefines specifications of the backup schedule.

Fields:
  cronSpec: Cron style schedule specification.
CrontabSpecr   r   N)	r   r   r   r   r   r   r(   cronSpecr   r   r    r!   r   r     s     ##M15(r    r   c                       \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " SS5      rSrg)	BatchCreateSessionsRequesti  a  The request for BatchCreateSessions.

Fields:
  sessionCount: Required. The number of sessions to be created in this batch
    call. At least one session is created. The API can return fewer than the
    requested number of sessions. If a specific number of sessions are
    desired, the client can make additional calls to `BatchCreateSessions`
    (adjusting session_count as necessary).
  sessionTemplate: Parameters to apply to each created session.
r   r`   Sessionr   r   N)r   r   r   r   r   r   rc   rd   re   sessionCountr(   sessionTemplater   r   r    r!   r   r     s9    	 ''93D3D3J3JK,**9a8/r    r   c                   <    \ rS rSrSr\R                  " SSSS9rSrg)	BatchCreateSessionsResponsei  zXThe response for BatchCreateSessions.

Fields:
  session: The freshly created sessions.
r   r   Tr$   r   N	r   r   r   r   r   r   r(   sessionr   r   r    r!   r   r     s     ""9a$?'r    r   c                       \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	\R                  " SS	5      r
S
rg)BatchWriteRequesti  a  The request for BatchWrite.

Fields:
  excludeTxnFromChangeStreams: Optional. If you don't set the
    `exclude_txn_from_change_streams` option or if it's set to `false`, then
    any change streams monitoring columns modified by transactions will
    capture the updates made within that transaction.
  mutationGroups: Required. The groups of mutations to be applied.
  requestOptions: Common options for this request.
r   MutationGroupr   Tr$   RequestOptionsr+   r   N)r   r   r   r   r   r   r;   excludeTxnFromChangeStreamsr(   mutationGroupsrequestOptionsr   r   r    r!   r   r     sA    	 !* 6 6q 9))/1tL.))*:A>.r    r   c                       \ rS rSrSr\R                  " S5      r\R                  " SS\R                  R                  S9r\R                  " SS5      rS	rg
)BatchWriteResponsei'  a  The result of applying a batch of mutations.

Fields:
  commitTimestamp: The commit timestamp of the transaction that applied this
    batch. Present if `status` is `OK`, absent otherwise.
  indexes: The mutation groups applied in this batch. The values index into
    the `mutation_groups` field in the corresponding `BatchWriteRequest`.
  status: An `OK` status indicates success. Any other status indicates a
    failure.
r   r   Tr%   ra   Statusr+   r   N)r   r   r   r   r   r   r   commitTimestamprc   rd   re   indexesr(   statusr   r   r    r!   r   r   '  sK    	 ))!,/""1tY=N=N=T=TU'!!(A.&r    r   c                       \ rS rSrSr\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r	S	r
g
)BeginTransactionRequesti8  a  The request for BeginTransaction.

Fields:
  mutationKey: Optional. Required for read-write transactions on a
    multiplexed session that commit mutations but don't perform any reads or
    queries. You must randomly select one of the mutations from the mutation
    set and send it as a part of this request.
  options: Required. Options for the new transaction.
  requestOptions: Common options for this request. Priority is ignored for
    this request. Setting the priority in this `request_options` struct
    doesn't do anything. To set the priority for a transaction, set it on
    the reads and writes that are part of this transaction instead.
Mutationr   TransactionOptionsr   r   r+   r   N)r   r   r   r   r   r   r(   mutationKeyoptionsr   r   r   r    r!   r   r   8  sA     &&z15+""#7;'))*:A>.r    r   c                       \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	\R                  " S5      r
S	rg
)BindingiL  at  Associates `members`, or principals, with a `role`.

Fields:
  condition: The condition that is associated with this binding. If the
    condition evaluates to `true`, then this binding applies to the current
    request. If the condition evaluates to `false`, then this binding does
    not apply to the current request. However, a different role binding
    might grant the same role to one or more of the principals in this
    binding. To learn which resources support conditions in their IAM
    policies, see the [IAM
    documentation](https://cloud.google.com/iam/help/conditions/resource-
    policies).
  members: Specifies the principals requesting access for a Google Cloud
    resource. `members` can have the following values: * `allUsers`: A
    special identifier that represents anyone who is on the internet; with
    or without a Google account. * `allAuthenticatedUsers`: A special
    identifier that represents anyone who is authenticated with a Google
    account or a service account. Does not include identities that come from
    external identity providers (IdPs) through identity federation. *
    `user:{emailid}`: An email address that represents a specific Google
    account. For example, `alice@example.com` . *
    `serviceAccount:{emailid}`: An email address that represents a Google
    service account. For example, `my-other-
    app@appspot.gserviceaccount.com`. *
    `serviceAccount:{projectid}.svc.id.goog[{namespace}/{kubernetes-sa}]`:
    An identifier for a [Kubernetes service
    account](https://cloud.google.com/kubernetes-engine/docs/how-
    to/kubernetes-service-accounts). For example, `my-
    project.svc.id.goog[my-namespace/my-kubernetes-sa]`. *
    `group:{emailid}`: An email address that represents a Google group. For
    example, `admins@example.com`. * `domain:{domain}`: The G Suite domain
    (primary) that represents all the users of that domain. For example,
    `google.com` or `example.com`. * `principal://iam.googleapis.com/locatio
    ns/global/workforcePools/{pool_id}/subject/{subject_attribute_value}`: A
    single identity in a workforce identity pool. * `principalSet://iam.goog
    leapis.com/locations/global/workforcePools/{pool_id}/group/{group_id}`:
    All workforce identities in a group. * `principalSet://iam.googleapis.co
    m/locations/global/workforcePools/{pool_id}/attribute.{attribute_name}/{
    attribute_value}`: All workforce identities with a specific attribute
    value. * `principalSet://iam.googleapis.com/locations/global/workforcePo
    ols/{pool_id}/*`: All identities in a workforce identity pool. * `princi
    pal://iam.googleapis.com/projects/{project_number}/locations/global/work
    loadIdentityPools/{pool_id}/subject/{subject_attribute_value}`: A single
    identity in a workload identity pool. * `principalSet://iam.googleapis.c
    om/projects/{project_number}/locations/global/workloadIdentityPools/{poo
    l_id}/group/{group_id}`: A workload identity pool group. * `principalSet
    ://iam.googleapis.com/projects/{project_number}/locations/global/workloa
    dIdentityPools/{pool_id}/attribute.{attribute_name}/{attribute_value}`:
    All identities in a workload identity pool with a certain attribute. * `
    principalSet://iam.googleapis.com/projects/{project_number}/locations/gl
    obal/workloadIdentityPools/{pool_id}/*`: All identities in a workload
    identity pool. * `deleted:user:{emailid}?uid={uniqueid}`: An email
    address (plus unique identifier) representing a user that has been
    recently deleted. For example,
    `alice@example.com?uid=123456789012345678901`. If the user is recovered,
    this value reverts to `user:{emailid}` and the recovered user retains
    the role in the binding. *
    `deleted:serviceAccount:{emailid}?uid={uniqueid}`: An email address
    (plus unique identifier) representing a service account that has been
    recently deleted. For example, `my-other-
    app@appspot.gserviceaccount.com?uid=123456789012345678901`. If the
    service account is undeleted, this value reverts to
    `serviceAccount:{emailid}` and the undeleted service account retains the
    role in the binding. * `deleted:group:{emailid}?uid={uniqueid}`: An
    email address (plus unique identifier) representing a Google group that
    has been recently deleted. For example,
    `admins@example.com?uid=123456789012345678901`. If the group is
    recovered, this value reverts to `group:{emailid}` and the recovered
    group retains the role in the binding. * `deleted:principal://iam.google
    apis.com/locations/global/workforcePools/{pool_id}/subject/{subject_attr
    ibute_value}`: Deleted single identity in a workforce identity pool. For
    example, `deleted:principal://iam.googleapis.com/locations/global/workfo
    rcePools/my-pool-id/subject/my-subject-attribute-value`.
  role: Role that is assigned to the list of `members`, or principals. For
    example, `roles/viewer`, `roles/editor`, or `roles/owner`. For an
    overview of the IAM roles and permissions, see the [IAM
    documentation](https://cloud.google.com/iam/docs/roles-overview). For a
    list of the available pre-defined roles, see
    [here](https://cloud.google.com/iam/docs/understanding-roles).
Exprr   r   Tr$   r+   r   N)r   r   r   r   r   r   r(   	conditionr   membersroler   r   r    r!   r   r   L  s?    Ob $$VQ/)!!!d3'			q	!$r    r   c                       \ rS rSrSr\R                  " S5      r\R                  " SS5      r	\R                  " S5      r
Srg)	ChangeQuorumMetadatai  a  Metadata type for the long-running operation returned by ChangeQuorum.

Fields:
  endTime: If set, the time at which this operation failed or was completed
    successfully.
  request: The request for ChangeQuorum.
  startTime: Time the request was received.
r   ChangeQuorumRequestr   r+   r   N)r   r   r   r   r   r   r   endTimer(   request	startTimer   r   r    r!   r   r     s<     !!!$'""#8!<'##A&)r    r   c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " SS5      r
Srg)	r   i  ap  The request for ChangeQuorum.

Fields:
  etag: Optional. The etag is the hash of the `QuorumInfo`. The
    `ChangeQuorum` operation is only performed if the etag matches that of
    the `QuorumInfo` in the current database resource. Otherwise the API
    returns an `ABORTED` error. The etag is used for optimistic concurrency
    control as a way to help prevent simultaneous change quorum requests
    that could create a race condition.
  name: Required. Name of the database in which to apply `ChangeQuorum`.
    Values are of the form `projects//instances//databases/`.
  quorumType: Required. The type of this quorum.
r   r   
QuorumTyper+   r   N)r   r   r   r   r   r   r   etagrB   r(   
quorumTyper   r   r    r!   r   r     s;     
		q	!$			q	!$%%lA6*r    r   c                       \ rS rSrSr\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r	\R                  " S	S
5      r
\R                  " SS5      rSrg)ChangeStreamRecordi  ap  Spanner Change Streams enable customers to capture and stream out
changes to their Spanner databases in real-time. A change stream can be
created with option partition_mode='IMMUTABLE_KEY_RANGE' or
partition_mode='MUTABLE_KEY_RANGE'. This message is only used in Change
Streams created with the option partition_mode='MUTABLE_KEY_RANGE'. Spanner
automatically creates a special Table-Valued Function (TVF) along with each
Change Streams. The function provides access to the change stream's records.
The function is named READ_ (where is the name of the change stream), and it
returns a table with only one column called ChangeRecord.

Fields:
  dataChangeRecord: Data change record describing a data change for a change
    stream partition.
  heartbeatRecord: Heartbeat record describing a heartbeat for a change
    stream partition.
  partitionEndRecord: Partition end record describing a terminated change
    stream partition.
  partitionEventRecord: Partition event record describing key range changes
    for a change stream partition.
  partitionStartRecord: Partition start record describing a new change
    stream partition.
DataChangeRecordr   HeartbeatRecordr   PartitionEndRecordr+   PartitionEventRecordrY   PartitionStartRecordrb   r   N)r   r   r   r   r   r   r(   dataChangeRecordheartbeatRecordpartitionEndRecordpartitionEventRecordpartitionStartRecordr   r   r    r!   r   r     sl    . ++,>B**+<a@/ --.BAF"//0FJ"//0FJr    r   c                       \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " S5      r\R                  " S5      rSrg)		ChildLinki  aj  Metadata associated with a parent-child relationship appearing in a
PlanNode.

Fields:
  childIndex: The node to which the link points.
  type: The type of the link. For example, in Hash Joins this could be used
    to distinguish between the build child and the probe child, or in the
    case of the child being an output variable, to represent the tag
    associated with the output variable.
  variable: Only present if the child node is SCALAR and corresponds to an
    output variable of the parent node. The field carries the name of the
    output variable. For example, a `TableScan` operator that reads rows
    from a table will have child links to the `SCALAR` nodes representing
    the output variables created for each column that is read by the
    operator. The corresponding `variable` fields will be set to the
    variable names assigned to the columns.
r   r`   r   r+   r   N)r   r   r   r   r   r   rc   rd   re   
childIndexr   typevariabler   r   r    r!   r   r     sG    $ %%a1B1B1H1HI*			q	!$""1%(r    r   c                       \ rS rSrSrSrg)ClientContexti  zLContainer for various pieces of client-owned context attached to a
request.
r   NrL   r   r    r!   r   r         r    r   c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r	\R                  " S5      r\R                  " SS5      rSrg	)
ColumnMetadatai  a%  Metadata for a column.

Fields:
  isPrimaryKey: Indicates whether the column is a primary key column.
  name: Name of the column.
  ordinalPosition: Ordinal position of the column based on the original
    table definition in the schema starting with a value of 1.
  type: Type of the column.
r   r   r+   TyperY   r   N)r   r   r   r   r   r   r;   isPrimaryKeyr   rB   rc   ordinalPositionr(   r   r   r   r    r!   r   r     sK     ''*,			q	!$**1-/				*$r    r   c                      \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	\R                  " SS	5      r
\R                  " S
S5      r\R                  " S5      r\R                  " SS5      r\R                  " S5      rSrg)CommitRequesti  a  The request for Commit.

Fields:
  maxCommitDelay: Optional. The amount of latency this request is configured
    to incur in order to improve throughput. If this field isn't set,
    Spanner assumes requests are relatively latency sensitive and
    automatically determines an appropriate delay time. You can specify a
    commit delay value between 0 and 500 ms.
  mutations: The mutations to be executed when this transaction commits. All
    mutations are applied atomically, in the order they appear in this list.
  precommitToken: Optional. If the read-write transaction was executed on a
    multiplexed session, then you must include the precommit token with the
    highest sequence number received in this transaction attempt. Failing to
    do so results in a `FailedPrecondition` error.
  requestOptions: Common options for this request.
  returnCommitStats: If `true`, then statistics related to the transaction
    is included in the CommitResponse. Default value is `false`.
  singleUseTransaction: Execute mutations in a temporary transaction. Note
    that unlike commit of a previously-started transaction, commit with a
    temporary transaction is non-idempotent. That is, if the `CommitRequest`
    is sent to Cloud Spanner more than once (for instance, due to retries in
    the application, or in the transport library), it's possible that the
    mutations are executed more than once. If this is undesirable, use
    BeginTransaction and Commit instead.
  transactionId: Commit a previously-started transaction.
r   r   r   Tr$    MultiplexedSessionPrecommitTokenr+   r   rY   rb   r   r   r   r   N)r   r   r   r   r   r   r   maxCommitDelayr(   	mutationsprecommitTokenr   r;   returnCommitStatssingleUseTransactionr.   transactionIdr   r   r    r!   r  r    s    6 ((+.$$ZTB)))*LaP.))*:A>.,,Q/"//0DaH&&q)-r    r  c                       \ rS rSrSr\R                  " SS5      r\R                  " S5      r	\R                  " SS5      r
\R                  " S5      rS	rg
)CommitResponsei:  at  The response for Commit.

Fields:
  commitStats: The statistics about this `Commit`. Not returned by default.
    For more information, see CommitRequest.return_commit_stats.
  commitTimestamp: The Cloud Spanner timestamp at which the transaction
    committed.
  precommitToken: If specified, transaction has not committed yet. You must
    retry the commit with the new precommit token.
  snapshotTimestamp: If `TransactionOptions.isolation_level` is set to
    `IsolationLevel.REPEATABLE_READ`, then the snapshot timestamp is the
    timestamp at which all reads in the transaction ran. This timestamp is
    never returned.
CommitStatsr   r   r  r+   rY   r   N)r   r   r   r   r   r   r(   commitStatsr   r   r	  snapshotTimestampr   r   r    r!   r  r  :  sO     &&}a8+))!,/))*LaP.++A.r    r  c                   <    \ rS rSrSr\R                  " S5      rSrg)r  iP  a  Additional statistics about a commit.

Fields:
  mutationCount: The total number of mutations for the transaction. Knowing
    the `mutation_count` value can help you maximize the number of mutations
    in a transaction and minimize the number of API round trips. You can
    also monitor this value to prevent transactions from exceeding the
    system [limit](https://cloud.google.com/spanner/quotas#limits_for_creati
    ng_reading_updating_and_deleting_data). If the number of mutations
    exceeds the limit, the server returns [INVALID_ARGUMENT](https://cloud.g
    oogle.com/spanner/docs/reference/rest/v1/Code#ENUM_VALUES.INVALID_ARGUME
    NT).
r   r   N)	r   r   r   r   r   r   rc   mutationCountr   r   r    r!   r  r  P  s     ((+-r    r  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " SS5      r
Srg)	CompactDatabaseMetadataib  a  Metadata type for the long-running operation returned by `CALL
compact_all()`, which can be executed using ExecuteSql or
ExecuteStreamingSql APIs.

Fields:
  cancelTime: Output only. The time at which cancellation of this operation
    was received. Operations.CancelOperation starts asynchronous
    cancellation on a long-running operation. The server makes a best effort
    to cancel the operation, but success is not guaranteed. Clients can use
    Operations.GetOperation or other methods to check whether the
    cancellation succeeded or whether the operation completed despite
    cancellation. On successful cancellation, the operation is not deleted;
    instead, it becomes an operation with an Operation.error value with a
    google.rpc.Status.code of 1, corresponding to `Code.CANCELLED`.
  database: Output only. The database being compacted.
  progress: Output only. The progress of the compaction operation.
r   r   OperationProgressr+   r   N)r   r   r   r   r   r   r   
cancelTimer   r(   progressr   r   r    r!   r  r  b  s<    $ $$Q'*""1%(##$7;(r    r  c                       \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	\R                  " SS5      r\R                  " S5      r\R                  " S	\R                  R                   S
9rSrg)ContextValueiz  aZ  A message representing context for a KeyRangeInfo, including a label,
value, unit, and severity.

Enums:
  SeverityValueValuesEnum: The severity of this context.

Fields:
  label: The label for the context value. e.g. "latency".
  severity: The severity of this context.
  unit: The unit of the context value.
  value: The value for the context.
c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
$ContextValue.SeverityValueValuesEnumi  a  The severity of this context.

Values:
  SEVERITY_UNSPECIFIED: Required default value.
  INFO: Lowest severity level "Info".
  WARNING: Middle severity level "Warning".
  ERROR: Severity level signaling an error "Error"
  FATAL: Severity level signaling a non recoverable error "Fatal"
r   r   r   r+   rY   r   Nr   r   r   r   r   SEVERITY_UNSPECIFIEDINFOWARNINGERRORFATALr   r   r    r!   SeverityValueValuesEnumr    #     DGEEr    r#  LocalizedStringr   r   r+   rY   r`   r   N)r   r   r   r   r   r   r   r#  r(   labelr   severityr   unit
FloatFieldrd   FLOATr   r   r   r    r!   r  r  z  sm    	   
 
 !2A
6%  !:A>(			q	!$


q)*;*;*A*A
B%r    r  c                       \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	\R                  " S5      r\R                  " SSS	9rS
rg)CopyBackupEncryptionConfigi  a  Encryption configuration for the copied backup.

Enums:
  EncryptionTypeValueValuesEnum: Required. The encryption type of the
    backup.

Fields:
  encryptionType: Required. The encryption type of the backup.
  kmsKeyName: Optional. This field is maintained for backwards
    compatibility. For new callers, we recommend using `kms_key_names` to
    specify the KMS key. Only use `kms_key_name` if the location of the KMS
    key matches the database instance's configuration (location) exactly.
    For example, if the KMS location is in `us-central1` or `nam3`, then the
    database instance must also be in `us-central1` or `nam3`. The Cloud KMS
    key that is used to encrypt and decrypt the restored database. Set this
    field only when encryption_type is `CUSTOMER_MANAGED_ENCRYPTION`. Values
    are of the form `projects//locations//keyRings//cryptoKeys/`.
  kmsKeyNames: Optional. Specifies the KMS configuration for the one or more
    keys used to protect the backup. Values are of the form
    `projects//locations//keyRings//cryptoKeys/`. KMS keys specified can be
    in any order. The keys referenced by `kms_key_names` must fully cover
    all regions of the backup's instance configuration. Some examples: * For
    regional (single-region) instance configurations, specify a regional
    location KMS key. * For multi-region instance configurations of type
    `GOOGLE_MANAGED`, either specify a multi-region location KMS key or
    multiple regional location KMS keys that cover all regions in the
    instance configuration. * For an instance configuration of type
    `USER_MANAGED`, specify only regional location KMS keys to cover each
    region in the instance configuration. Multi-region location KMS keys
    aren't supported for `USER_MANAGED` type instance configurations.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	8CopyBackupEncryptionConfig.EncryptionTypeValueValuesEnumi  af  Required. The encryption type of the backup.

Values:
  ENCRYPTION_TYPE_UNSPECIFIED: Unspecified. Do not use.
  USE_CONFIG_DEFAULT_OR_BACKUP_ENCRYPTION: This is the default option for
    CopyBackup when encryption_config is not specified. For example, if
    the source backup is using `Customer_Managed_Encryption`, the backup
    will be using the same Cloud KMS key as the source backup.
  GOOGLE_DEFAULT_ENCRYPTION: Use Google default encryption.
  CUSTOMER_MANAGED_ENCRYPTION: Use customer managed encryption. If
    specified, either `kms_key_name` or `kms_key_names` must contain valid
    Cloud KMS keys.
r   r   r   r+   r   N
r   r   r   r   r   ENCRYPTION_TYPE_UNSPECIFIED'USE_CONFIG_DEFAULT_OR_BACKUP_ENCRYPTIONGOOGLE_DEFAULT_ENCRYPTIONCUSTOMER_MANAGED_ENCRYPTIONr   r   r    r!   EncryptionTypeValueValuesEnumr.    s!     #$./+ !"#r    r4  r   r   r+   Tr$   r   Nr   r   r   r   r   r   r   r4  r   encryptionTyper   
kmsKeyNamekmsKeyNamesr   r   r    r!   r,  r,    sO    @$inn $& &&'FJ.$$Q'*%%a$7+r    r,  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " SS5      r
\R                  " S5      rSrg	)
CopyBackupMetadatai  a  Metadata type for the operation returned by CopyBackup.

Fields:
  cancelTime: The time at which cancellation of CopyBackup operation was
    received. Operations.CancelOperation starts asynchronous cancellation on
    a long-running operation. The server makes a best effort to cancel the
    operation, but success is not guaranteed. Clients can use
    Operations.GetOperation or other methods to check whether the
    cancellation succeeded or whether the operation completed despite
    cancellation. On successful cancellation, the operation is not deleted;
    instead, it becomes an operation with an Operation.error value with a
    google.rpc.Status.code of 1, corresponding to `Code.CANCELLED`.
  name: The name of the backup being created through the copy operation.
    Values are of the form `projects//instances//backups/`.
  progress: The progress of the CopyBackup operation.
  sourceBackup: The name of the source backup that is being copied. Values
    are of the form `projects//instances//backups/`.
r   r   r  r+   rY   r   N)r   r   r   r   r   r   r   r  rB   r(   r  sourceBackupr   r   r    r!   r:  r:    sL    & $$Q'*			q	!$##$7;(&&q),r    r:  c                       \ rS rSrSr\R                  " S5      r\R                  " SS5      r	\R                  " S5      r
\R                  " S5      rSrg	)
CopyBackupRequesti  a  The request for CopyBackup.

Fields:
  backupId: Required. The id of the backup copy. The `backup_id` appended to
    `parent` forms the full backup_uri of the form
    `projects//instances//backups/`.
  encryptionConfig: Optional. The encryption configuration used to encrypt
    the backup. If this field is not specified, the backup will use the same
    encryption configuration as the source backup by default, namely
    encryption_type = `USE_CONFIG_DEFAULT_OR_BACKUP_ENCRYPTION`.
  expireTime: Required. The expiration time of the backup in microsecond
    granularity. The expiration time must be at least 6 hours and at most
    366 days from the `create_time` of the source backup. Once the
    `expire_time` has passed, the backup is eligible to be automatically
    deleted by Cloud Spanner to free the resources used by the backup.
  sourceBackup: Required. The source backup to be copied. The source backup
    needs to be in READY state for it to be copied. Once CopyBackup is in
    progress, the source backup cannot be deleted or cleaned up on
    expiration until CopyBackup is finished. Values are of the form:
    `projects//instances//backups/`.
r   r,  r   r+   rY   r   N)r   r   r   r   r   r   r   backupIdr(   r   r   r;  r   r   r    r!   r=  r=    sM    , ""1%(++,H!L$$Q'*&&q),r    r=  c                       \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	\R                  " S5      r\R                  " SSS	9rS
rg)r   i  a  Encryption configuration for the backup to create.

Enums:
  EncryptionTypeValueValuesEnum: Required. The encryption type of the
    backup.

Fields:
  encryptionType: Required. The encryption type of the backup.
  kmsKeyName: Optional. This field is maintained for backwards
    compatibility. For new callers, we recommend using `kms_key_names` to
    specify the KMS key. Only use `kms_key_name` if the location of the KMS
    key matches the database instance's configuration (location) exactly.
    For example, if the KMS location is in `us-central1` or `nam3`, then the
    database instance must also be in `us-central1` or `nam3`. The Cloud KMS
    key that is used to encrypt and decrypt the restored database. Set this
    field only when encryption_type is `CUSTOMER_MANAGED_ENCRYPTION`. Values
    are of the form `projects//locations//keyRings//cryptoKeys/`.
  kmsKeyNames: Optional. Specifies the KMS configuration for the one or more
    keys used to protect the backup. Values are of the form
    `projects//locations//keyRings//cryptoKeys/`. The keys referenced by
    `kms_key_names` must fully cover all regions of the backup's instance
    configuration. Some examples: * For regional (single-region) instance
    configurations, specify a regional location KMS key. * For multi-region
    instance configurations of type `GOOGLE_MANAGED`, either specify a
    multi-region location KMS key or multiple regional location KMS keys
    that cover all regions in the instance configuration. * For an instance
    configuration of type `USER_MANAGED`, specify only regional location KMS
    keys to cover each region in the instance configuration. Multi-region
    location KMS keys aren't supported for `USER_MANAGED` type instance
    configurations.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	:CreateBackupEncryptionConfig.EncryptionTypeValueValuesEnumi/  O  Required. The encryption type of the backup.

Values:
  ENCRYPTION_TYPE_UNSPECIFIED: Unspecified. Do not use.
  USE_DATABASE_ENCRYPTION: Use the same encryption configuration as the
    database. This is the default option when encryption_config is empty.
    For example, if the database is using `Customer_Managed_Encryption`,
    the backup will be using the same Cloud KMS key as the database.
  GOOGLE_DEFAULT_ENCRYPTION: Use Google default encryption.
  CUSTOMER_MANAGED_ENCRYPTION: Use customer managed encryption. If
    specified, `kms_key_name` must contain a valid Cloud KMS key.
r   r   r   r+   r   N
r   r   r   r   r   r0  USE_DATABASE_ENCRYPTIONr2  r3  r   r   r    r!   r4  rA  /  !     #$ !"#r    r4  r   r   r+   Tr$   r   Nr5  r   r    r!   r   r     sO    @$inn $$ &&'FJ.$$Q'*%%a$7+r    r   c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S5      r	\R                  " SS5      rSrg	)
CreateBackupMetadataiF  af  Metadata type for the operation returned by CreateBackup.

Fields:
  cancelTime: The time at which cancellation of this operation was received.
    Operations.CancelOperation starts asynchronous cancellation on a long-
    running operation. The server makes a best effort to cancel the
    operation, but success is not guaranteed. Clients can use
    Operations.GetOperation or other methods to check whether the
    cancellation succeeded or whether the operation completed despite
    cancellation. On successful cancellation, the operation is not deleted;
    instead, it becomes an operation with an Operation.error value with a
    google.rpc.Status.code of 1, corresponding to `Code.CANCELLED`.
  database: The name of the database the backup is created from.
  name: The name of the backup being created.
  progress: The progress of the CreateBackup operation.
r   r   r+   r  rY   r   N)r   r   r   r   r   r   r   r  r   rB   r(   r  r   r   r    r!   rG  rG  F  sL    " $$Q'*""1%(			q	!$##$7;(r    rG  c                   <    \ rS rSrSr\R                  " S5      rSrg)CreateDatabaseMetadatai^  zmMetadata type for the operation returned by CreateDatabase.

Fields:
  database: The database being created.
r   r   N	r   r   r   r   r   r   r   r   r   r   r    r!   rI  rI  ^  s     ""1%(r    rI  c                       \ rS rSrSr " S S\R                  5      r\R                  " S5      r	\R                  " SS5      r\R                  " SS5      r\R                  " S	S
S9r\R                  " S5      rSrg)CreateDatabaseRequestih  aR  The request for CreateDatabase.

Enums:
  DatabaseDialectValueValuesEnum: Optional. The dialect of the Cloud Spanner
    Database.

Fields:
  createStatement: Required. A `CREATE DATABASE` statement, which specifies
    the ID of the new database. The database ID must conform to the regular
    expression `a-z*[a-z0-9]` and be between 2 and 30 characters in length.
    If the database ID is a reserved word or if it contains a hyphen, the
    database ID must be enclosed in backticks (`` ` ``).
  databaseDialect: Optional. The dialect of the Cloud Spanner Database.
  encryptionConfig: Optional. The encryption configuration for the database.
    If this field is not specified, Cloud Spanner will encrypt/decrypt all
    data at rest using Google default encryption.
  extraStatements: Optional. A list of DDL statements to run inside the
    newly created database. Statements can create tables, indexes, etc.
    These statements execute atomically with the creation of the database:
    if there is an error in any statement, the database is not created.
  protoDescriptors: Optional. Proto descriptors used by `CREATE/ALTER PROTO
    BUNDLE` statements in 'extra_statements'. Contains a protobuf-serialized
    [`google.protobuf.FileDescriptorSet`](https://github.com/protocolbuffers
    /protobuf/blob/main/src/google/protobuf/descriptor.proto) descriptor
    set. To generate it, [install](https://grpc.io/docs/protoc-
    installation/) and run `protoc` with --include_imports and
    --descriptor_set_out. For example, to generate for moon/shot/app.proto,
    run ``` $protoc --proto_path=/app_path --proto_path=/lib_path \
    --include_imports \ --descriptor_set_out=descriptors.data \
    moon/shot/app.proto ``` For more details, see protobuffer [self
    description](https://developers.google.com/protocol-
    buffers/docs/techniques#self-description).
c                   $    \ rS rSrSrSrSrSrSrg)4CreateDatabaseRequest.DatabaseDialectValueValuesEnumi  a  Optional. The dialect of the Cloud Spanner Database.

Values:
  DATABASE_DIALECT_UNSPECIFIED: Default value. This value will create a
    database with the GOOGLE_STANDARD_SQL dialect.
  GOOGLE_STANDARD_SQL: GoogleSQL supported SQL.
  POSTGRESQL: PostgreSQL supported SQL.
r   r   r   r   Nry   r   r    r!   r}   rN    r~   r    r}   r   r   EncryptionConfigr+   rY   Tr$   rb   r   N)r   r   r   r   r   r   r   r}   r   createStatementr   r   r(   r   extraStatementsr.   protoDescriptorsr   r   r    r!   rL  rL  h  st     Dy~~  ))!,/''(H!L/++,>B))!d;/))!,r    rL  c                       \ rS rSrSr\R                  " S5      r\R                  " SS5      r	\R                  " SS5      r
Srg	)
CreateInstanceConfigMetadatai  a  Metadata type for the operation returned by CreateInstanceConfig.

Fields:
  cancelTime: The time at which this operation was cancelled.
  instanceConfig: The target instance configuration end state.
  progress: The progress of the CreateInstanceConfig operation.
r   InstanceConfigr   InstanceOperationProgressr+   r   Nr   r   r   r   r   r   r   r  r(   instanceConfigr  r   r   r    r!   rT  rT    ?     $$Q'*))*:A>.##$?C(r    rT  c                       \ rS rSrSr\R                  " SS5      r\R                  " S5      r	\R                  " S5      rSrg)	CreateInstanceConfigRequesti  a  The request for CreateInstanceConfig.

Fields:
  instanceConfig: Required. The `InstanceConfig` proto of the configuration
    to create. `instance_config.name` must be `/instanceConfigs/`.
    `instance_config.base_config` must be a Google-managed configuration
    name, e.g. /instanceConfigs/us-east1, /instanceConfigs/nam3.
  instanceConfigId: Required. The ID of the instance configuration to
    create. Valid identifiers are of the form `custom-[-a-z0-9]*[a-z0-9]`
    and must be between 2 and 64 characters in length. The `custom-` prefix
    is required to avoid name conflicts with Google-managed configurations.
  validateOnly: An option to validate, but not actually execute, a request,
    and provide the same response.
rU  r   r   r+   r   N)r   r   r   r   r   r   r(   rX  r   instanceConfigIdr;   validateOnlyr   r   r    r!   r[  r[    s=     ))*:A>.**1-''*,r    r[  c                       \ rS rSrSr " S S\R                  5      r\R                  " S5      r	\R                  " S5      r
\R                  " SS5      r\R                  " SS	5      r\R                  " S
5      rSrg)CreateInstanceMetadatai  a  Metadata type for the operation returned by CreateInstance.

Enums:
  ExpectedFulfillmentPeriodValueValuesEnum: The expected fulfillment period
    of this create operation.

Fields:
  cancelTime: The time at which this operation was cancelled. If set, this
    operation is in the process of undoing itself (which is guaranteed to
    succeed) and cannot be cancelled again.
  endTime: The time at which this operation failed or was completed
    successfully.
  expectedFulfillmentPeriod: The expected fulfillment period of this create
    operation.
  instance: The instance being created.
  startTime: The time at which the CreateInstance request was received.
c                   $    \ rS rSrSrSrSrSrSrg)?CreateInstanceMetadata.ExpectedFulfillmentPeriodValueValuesEnumi  a_  The expected fulfillment period of this create operation.

Values:
  FULFILLMENT_PERIOD_UNSPECIFIED: Not specified.
  FULFILLMENT_PERIOD_NORMAL: Normal fulfillment period. The operation is
    expected to complete within minutes.
  FULFILLMENT_PERIOD_EXTENDED: Extended fulfillment period. It can take up
    to an hour for the operation to complete.
r   r   r   r   N	r   r   r   r   r   FULFILLMENT_PERIOD_UNSPECIFIEDFULFILLMENT_PERIOD_NORMALFULFILLMENT_PERIOD_EXTENDEDr   r   r    r!   (ExpectedFulfillmentPeriodValueValuesEnumra         &'" !"#r    rf  r   r   r+   InstancerY   rb   r   Nr   r   r   r   r   r   r   rf  r   r  r   r   expectedFulfillmentPeriodr(   instancer   r   r   r    r!   r_  r_    p    $$ $ $$Q'*!!!$''112\^_`##J2(##A&)r    r_  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " SS5      r
\R                  " S5      rSrg	)
CreateInstancePartitionMetadatai  a  Metadata type for the operation returned by CreateInstancePartition.

Fields:
  cancelTime: The time at which this operation was cancelled. If set, this
    operation is in the process of undoing itself (which is guaranteed to
    succeed) and cannot be cancelled again.
  endTime: The time at which this operation failed or was completed
    successfully.
  instancePartition: The instance partition being created.
  startTime: The time at which the CreateInstancePartition request was
    received.
r   r   InstancePartitionr+   rY   r   Nr   r   r   r   r   r   r   r  r   r(   r   r   r   r   r    r!   rn  rn    sM     $$Q'*!!!$',,-@!D##A&)r    rn  c                   b    \ rS rSrSr\R                  " SS5      r\R                  " S5      r	Sr
g)CreateInstancePartitionRequesti  a  The request for CreateInstancePartition.

Fields:
  instancePartition: Required. The instance partition to create. The
    instance_partition.name may be omitted, but if specified must be
    `/instancePartitions/`.
  instancePartitionId: Required. The ID of the instance partition to create.
    Valid identifiers are of the form `a-z*[a-z0-9]` and must be between 2
    and 64 characters in length.
ro  r   r   r   N)r   r   r   r   r   r   r(   r   r   instancePartitionIdr   r   r    r!   rr  rr    s.    	  ,,-@!D!--a0r    rr  c                       \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " SS5      r\R                  " S5      r\R                  " SS	5      rS
rg)CreateInstanceRequesti  a
  The request for CreateInstance.

Messages:
  TagsValue: Optional. The resource tags that should be bound to the
    instance upon creation.

Fields:
  instance: Required. The instance to create. The name may be omitted, but
    if specified must be `/instances/`.
  instanceId: Required. The ID of the instance to create. Valid identifiers
    are of the form `a-z*[a-z0-9]` and must be between 2 and 64 characters
    in length.
  tags: Optional. The resource tags that should be bound to the instance
    upon creation.
r   c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
CreateInstanceRequest.TagsValuei  zOptional. The resource tags that should be bound to the instance upon
creation.

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

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

Fields:
  key: Name of the additional property.
  value: A string attribute.
r   r   r   Nr   r   r    r!   r"   ry  +  r#   r    r"   r   Tr$   r   Nr&   r   r    r!   	TagsValuerw    r*   r    r{  rh  r   r   r+   r   N)r   r   r   r   r   r   r,   r   r'   r{  r(   rk  r   
instanceIdtagsr   r   r    r!   ru  ru    sm      !!"89Z)## Z :Z0 ##J2($$Q'*			Q	/$r    ru  c                   >    \ rS rSrSr\R                  " SS5      rSrg)CreateSessionRequesti=  zTThe request for CreateSession.

Fields:
  session: Required. The session to create.
r   r   r   Nr   r   r    r!   r  r  =  s     ""9a0'r    r  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S5      r	Sr
g)r   iG  a_  CrontabSpec can be used to specify the version time and frequency at
which the backup is created.

Fields:
  creationWindow: Output only. Scheduled backups contain an externally
    consistent copy of the database at the version time specified in
    `schedule_spec.cron_spec`. However, Spanner might not initiate the
    creation of the scheduled backups at that version time. Spanner
    initiates the creation of scheduled backups within the time window
    bounded by the version_time specified in `schedule_spec.cron_spec` and
    version_time + `creation_window`.
  text: Required. Textual representation of the crontab. User can customize
    the backup frequency and the backup version time using the cron
    expression. The version time must be in UTC timezone. The backup will
    contain an externally consistent copy of the database at the version
    time. Full backups must be scheduled a minimum of 12 hours apart and
    incremental backups must be scheduled a minimum of 4 hours apart.
    Examples of valid cron specifications: * `0 2/12 * * *` : every 12 hours
    at (2, 14) hours past midnight in UTC. * `0 2,14 * * *` : every 12 hours
    at (2, 14) hours past midnight in UTC. * `0 */4 * * *` : (incremental
    backups only) every 4 hours at (0, 4, 8, 12, 16, 20) hours past midnight
    in UTC. * `0 2 * * *` : once a day at 2 past midnight in UTC. * `0 2 * *
    0` : once a week every Sunday at 2 past midnight in UTC. * `0 2 8 * *` :
    once a month on 8th day at 2 past midnight in UTC.
  timeZone: Output only. The time zone of the times in `CrontabSpec.text`.
    Currently, only UTC is supported.
r   r   r+   r   N)r   r   r   r   r   r   r   creationWindowtexttimeZoner   r   r    r!   r   r   G  s9    8 ((+.			q	!$""1%(r    r   c                      \ rS rSrSr " S S\R                  5      r " S S\R                  5      r\R                  " SSS	S
9r
\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                   " SS5      r\R                  " SSS	S
9r\R&                  " S\R(                  R*                  S9r\R&                  " S\R(                  R*                  S9r\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                   " SS5      rSrg)r   ii  a  A data change record contains a set of changes to a table with the same
modification type (insert, update, or delete) committed at the same commit
timestamp in one change stream partition for the same transaction. Multiple
data change records can be returned for the same transaction across multiple
change stream partitions.

Enums:
  ModTypeValueValuesEnum: Describes the type of change.
  ValueCaptureTypeValueValuesEnum: Describes the value capture type that was
    specified in the change stream configuration when this change was
    captured.

Fields:
  columnMetadata: Provides metadata describing the columns associated with
    the mods listed below.
  commitTimestamp: Indicates the timestamp in which the change was
    committed. DataChangeRecord.commit_timestamps,
    PartitionStartRecord.start_timestamps,
    PartitionEventRecord.commit_timestamps, and
    PartitionEndRecord.end_timestamps can have the same value in the same
    partition.
  isLastRecordInTransactionInPartition: Indicates whether this is the last
    record for a transaction in the current partition. Clients can use this
    field to determine when all records for a transaction in the current
    partition have been received.
  isSystemTransaction: Indicates whether the transaction is a system
    transaction. System transactions include those issued by time-to-live
    (TTL), column backfill, etc.
  modType: Describes the type of change.
  mods: Describes the changes that were made.
  numberOfPartitionsInTransaction: Indicates the number of partitions that
    return data change records for this transaction. This value can be
    helpful in assembling all records associated with a particular
    transaction.
  numberOfRecordsInTransaction: Indicates the number of data change records
    that are part of this transaction across all change stream partitions.
    This value can be used to assemble all the records associated with a
    particular transaction.
  recordSequence: Record sequence numbers are unique and monotonically
    increasing (but not necessarily contiguous) for a specific timestamp
    across record types in the same partition. To guarantee ordered
    processing, the reader should process records (of potentially different
    types) in record_sequence order for a specific timestamp in the same
    partition. The record sequence number ordering across partitions is only
    meaningful in the context of a specific transaction. Record sequence
    numbers are unique across partitions for a specific transaction. Sort
    the DataChangeRecords for the same server_transaction_id by
    record_sequence to reconstruct the ordering of the changes within the
    transaction.
  serverTransactionId: Provides a globally unique string that represents the
    transaction in which the change was committed. Multiple transactions can
    have the same commit timestamp, but each transaction has a unique
    server_transaction_id.
  table: Name of the table affected by the change.
  transactionTag: Indicates the transaction tag associated with this
    transaction.
  valueCaptureType: Describes the value capture type that was specified in
    the change stream configuration when this change was captured.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	'DataChangeRecord.ModTypeValueValuesEnumi  zDescribes the type of change.

Values:
  MOD_TYPE_UNSPECIFIED: Not specified.
  INSERT: Indicates data was inserted.
  UPDATE: Indicates existing data was updated.
  DELETE: Indicates existing data was deleted.
r   r   r   r+   r   N)
r   r   r   r   r   MOD_TYPE_UNSPECIFIEDINSERTUPDATEDELETEr   r   r    r!   ModTypeValueValuesEnumr    s     FFFr    r  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
0DataChangeRecord.ValueCaptureTypeValueValuesEnumi  ah  Describes the value capture type that was specified in the change
stream configuration when this change was captured.

Values:
  VALUE_CAPTURE_TYPE_UNSPECIFIED: Not specified.
  OLD_AND_NEW_VALUES: Records both old and new values of the modified
    watched columns.
  NEW_VALUES: Records only new values of the modified watched columns.
  NEW_ROW: Records new values of all watched columns, including modified
    and unmodified columns.
  NEW_ROW_AND_OLD_VALUES: Records the new values of all watched columns,
    including modified and unmodified columns. Also records the old values
    of the modified columns.
r   r   r   r+   rY   r   N)r   r   r   r   r   VALUE_CAPTURE_TYPE_UNSPECIFIEDOLD_AND_NEW_VALUES
NEW_VALUESNEW_ROWNEW_ROW_AND_OLD_VALUESr   r   r    r!   ValueCaptureTypeValueValuesEnumr    s%     &'"JGr    r  r   r   Tr$   r   r+   rY   rb   Modr   r   r`   r   r   r   r   r   r   r   N)r   r   r   r   r   r   r   r  r  r(   columnMetadatar   r   r;   $isLastRecordInTransactionInPartitionisSystemTransactionr   modTypemodsrc   rd   re   numberOfPartitionsInTransactionnumberOfRecordsInTransactionrecordSequenceserverTransactionIdtabletransactionTagvalueCaptureTyper   r   r    r!   r   r   i  s+   :xy~~ 	 * ))*:AM.))!,/)2)?)?)B&!..q1 8!<'			q4	8$$-$:$:1iFWFWF]F]$^!!*!7!79CTCTCZCZ![((+.!--b1



#%((,.(()JBOr    r   c                   J   \ rS rSrSr " S S\R                  5      r " S S\R                  5      r\R                  " S5      r
\R                  " SS5      r\R                  " S	5      r\R                  " S
5      r\R                  " S5      r\R"                  " SS5      r\R"                  " SSSS9r\R                  " S5      r\R"                  " SS5      r\R                  " S5      r\R"                  " SS5      r\R                  " SS5      r\R                  " S5      rSrg)Databasei  a$  A Cloud Spanner database.

Enums:
  DatabaseDialectValueValuesEnum: Output only. The dialect of the Cloud
    Spanner Database.
  StateValueValuesEnum: Output only. The current database state.

Fields:
  createTime: Output only. If exists, the time at which the database
    creation started.
  databaseDialect: Output only. The dialect of the Cloud Spanner Database.
  defaultLeader: Output only. The read-write region which contains the
    database's leader replicas. This is the same as the value of
    default_leader database option set using DatabaseAdmin.CreateDatabase or
    DatabaseAdmin.UpdateDatabaseDdl. If not explicitly set, this is empty.
  earliestVersionTime: Output only. Earliest timestamp at which older
    versions of the data can be read. This value is continuously updated by
    Cloud Spanner and becomes stale the moment it is queried. If you are
    using this value to recover data, make sure to account for the time from
    the moment when the value is queried to the moment when you initiate the
    recovery.
  enableDropProtection: Optional. Whether drop protection is enabled for
    this database. Defaults to false, if not set. For more details, please
    see how to [prevent accidental database
    deletion](https://cloud.google.com/spanner/docs/prevent-database-
    deletion).
  encryptionConfig: Output only. For databases that are using customer
    managed encryption, this field contains the encryption configuration for
    the database. For databases that are using Google default or other types
    of encryption, this field is empty.
  encryptionInfo: Output only. For databases that are using customer managed
    encryption, this field contains the encryption information for the
    database, such as all Cloud KMS key versions that are in use. The
    `encryption_status` field inside of each `EncryptionInfo` is not
    populated. For databases that are using Google default or other types of
    encryption, this field is empty. This field is propagated lazily from
    the backend. There might be a delay from when a key version is being
    used and when it appears in this field.
  name: Required. The name of the database. Values are of the form
    `projects//instances//databases/`, where `` is as specified in the
    `CREATE DATABASE` statement. This name can be passed to other API
    methods to identify the database.
  quorumInfo: Output only. Applicable only for databases that use dual-
    region instance configurations. Contains information about the quorum.
  reconciling: Output only. If true, the database is being updated. If
    false, there are no ongoing update operations for the database.
  restoreInfo: Output only. Applicable only for restored databases. Contains
    information about the restore source.
  state: Output only. The current database state.
  versionRetentionPeriod: Output only. The period in which Cloud Spanner
    retains all versions of data for the database. This is the same as the
    value of version_retention_period database option set using
    UpdateDatabaseDdl. Defaults to 1 hour, if not set.
c                   $    \ rS rSrSrSrSrSrSrg)'Database.DatabaseDialectValueValuesEnumi  a  Output only. The dialect of the Cloud Spanner Database.

Values:
  DATABASE_DIALECT_UNSPECIFIED: Default value. This value will create a
    database with the GOOGLE_STANDARD_SQL dialect.
  GOOGLE_STANDARD_SQL: GoogleSQL supported SQL.
  POSTGRESQL: PostgreSQL supported SQL.
r   r   r   r   Nry   r   r    r!   r}   r    r~   r    r}   c                   (    \ rS rSrSrSrSrSrSrSr	g)	Database.StateValueValuesEnumi  a  Output only. The current database state.

Values:
  STATE_UNSPECIFIED: Not specified.
  CREATING: The database is still being created. Operations on the
    database may fail with `FAILED_PRECONDITION` in this state.
  READY: The database is fully created and ready for use.
  READY_OPTIMIZING: The database is fully created and ready for use, but
    is still being optimized for performance and cannot handle full load.
    In this state, the database still references the backup it was restore
    from, preventing the backup from being deleted. When optimizations are
    complete, the full performance of the database will be restored, and
    the database will transition to `READY` state.
r   r   r   r+   r   N)
r   r   r   r   r   r   r   r   READY_OPTIMIZINGr   r   r    r!   r   r    s     HEr    r   r   r   r+   rY   rb   rO  r   r   r   Tr$   r   
QuorumInfor   r   RestoreInfor   r   r   r   N)r   r   r   r   r   r   r   r}   r   r   r   r   r   defaultLeaderearliestVersionTimer;   enableDropProtectionr(   r   r   rB   
quorumInforeconcilingrestoreInfor   versionRetentionPeriodr   r   r    r!   r  r    s   5ny~~ Y^^ ( $$Q'*''(H!L/''*-!--a0"//2++,>B))*:AM.			q	!$%%lA6*&&r*+&&}b9+


4b
9%$004r    r  c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)DatabaseMoveConfigi@  a  The configuration for each database in the target instance
configuration.

Fields:
  databaseId: Required. The unique identifier of the database resource in
    the Instance. For example, if the database uri is
    `projects/foo/instances/bar/databases/baz`, then the id to supply here
    is baz.
  encryptionConfig: Optional. Encryption configuration to be used for the
    database in the target configuration. The encryption configuration must
    be specified for every database which currently uses CMEK encryption. If
    a database currently uses Google-managed encryption and a target
    encryption configuration is not specified, then the database defaults to
    Google-managed encryption. If a database currently uses Google-managed
    encryption and a target CMEK encryption is specified, the request is
    rejected. If a database currently uses CMEK encryption, then a target
    encryption configuration must be specified. You can't move a CMEK
    database to a Google-managed encryption database using the MoveInstance
    API.
r   InstanceEncryptionConfigr   r   N)r   r   r   r   r   r   r   
databaseIdr(   r   r   r   r    r!   r  r  @  s-    * $$Q'*++,FJr    r  c                   <    \ rS rSrSr\R                  " S5      rSrg)DatabaseRoleiZ  zA Cloud Spanner database role.

Fields:
  name: Required. The name of the database role. Values are of the form
    `projects//instances//databases//databaseRoles/` where `` is as
    specified in the `CREATE ROLE` DDL statement.
r   r   NrA   r   r    r!   r  r  Z  s     
		q	!$r    r  c                       \ rS rSrSr\R                  " S5      r\R                  " SSS9r\R                  " S5      r	Sr
g	)
DdlStatementActionInfoif  a  Action information extracted from a DDL statement. This proto is used to
display the brief info of the DDL statement for the operation
UpdateDatabaseDdl.

Fields:
  action: The action for the DDL statement, for example, CREATE, ALTER,
    DROP, GRANT, etc. This field is a non-empty string.
  entityNames: The entity names being operated on the DDL statement. For
    example, 1. For statement "CREATE TABLE t1(...)", `entity_names` =
    ["t1"]. 2. For statement "GRANT ROLE r1, r2 ...", `entity_names` =
    ["r1", "r2"]. 3. For statement "ANALYZE", `entity_names` = [].
  entityType: The entity type for the DDL statement, for example, TABLE,
    INDEX, VIEW, etc. This field can be empty string for some DDL statement,
    for example, for statement "ANALYZE", `entity_type` = "".
r   r   Tr$   r+   r   N)r   r   r   r   r   r   r   actionentityNames
entityTyper   r   r    r!   r  r  f  s;        #&%%a$7+$$Q'*r    r  c                   b    \ rS rSrSr\R                  " SS5      r\R                  " S5      r	Sr
g)Deletei|  a  Arguments to delete operations.

Fields:
  keySet: Required. The primary keys of the rows within table to delete. The
    primary keys must be specified in the order in which they appear in the
    `PRIMARY KEY()` clause of the table's equivalent DDL statement (the DDL
    statement used to create the table). Delete is idempotent. The
    transaction will succeed even if some or all rows do not exist.
  table: Required. The table whose rows will be deleted.
KeySetr   r   r   N)r   r   r   r   r   r   r(   keySetr   r  r   r   r    r!   r  r  |  s+    	 !!(A.&



"%r    r  c                   d    \ rS rSrSr\R                  " SS5      r\R                  " SS5      rSr	g)DerivedMetrici  zA message representing a derived metric.

Fields:
  denominator: The name of the denominator metric. e.g. "rows".
  numerator: The name of the numerator metric. e.g. "latency".
r%  r   r   r   N)
r   r   r   r   r   r   r(   denominator	numeratorr   r   r    r!   r  r    s/     &&'8!<+$$%6:)r    r  c                       \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	\R                  " SS5      r
\R                  " S5      r\R                  " SS	5      r\R                  " SS
5      rSrg)DiagnosticMessagei  a  A message representing the key visualizer diagnostic messages.

Enums:
  SeverityValueValuesEnum: The severity of the diagnostic message.

Fields:
  info: Information about this diagnostic information.
  metric: The metric.
  metricSpecific: Whether this message is specific only for the current
    metric. By default Diagnostics are shown for all metrics, regardless
    which metric is the currently selected metric in the UI. However
    occasionally a metric will generate so many messages that the resulting
    visual clutter becomes overwhelming. In this case setting this to true,
    will show the diagnostic messages for that metric only if it is the
    currently selected metric.
  severity: The severity of the diagnostic message.
  shortMessage: The short message.
c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
)DiagnosticMessage.SeverityValueValuesEnumi  a(  The severity of the diagnostic message.

Values:
  SEVERITY_UNSPECIFIED: Required default value.
  INFO: Lowest severity level "Info".
  WARNING: Middle severity level "Warning".
  ERROR: Severity level signaling an error "Error"
  FATAL: Severity level signaling a non recoverable error "Fatal"
r   r   r   r+   rY   r   Nr  r   r    r!   r#  r    r$  r    r#  r%  r   r   r+   rY   rb   r   N)r   r   r   r   r   r   r   r#  r(   infometricr;   metricSpecificr   r'  shortMessager   r   r    r!   r  r    su    &	   
		 11	5$!!"3Q7&))!,.  !:A>(''(91=,r    r  c                   d    \ rS rSrSr\R                  " SS5      r\R                  " SS5      rSr	g)	DirectedReadOptionsi  a6  The `DirectedReadOptions` can be used to indicate which replicas or
regions should be used for non-transactional reads or queries.
`DirectedReadOptions` can only be specified for a read-only transaction,
otherwise the API returns an `INVALID_ARGUMENT` error.

Fields:
  excludeReplicas: `Exclude_replicas` indicates that specified replicas
    should be excluded from serving requests. Spanner doesn't route requests
    to the replicas in this list.
  includeReplicas: `Include_replicas` indicates the order of replicas (as
    they appear in this list) to process the request. If
    `auto_failover_disabled` is set to `true` and all replicas are exhausted
    without finding a healthy replica, Spanner waits for a replica in the
    list to become available, requests might fail due to `DEADLINE_EXCEEDED`
    errors.
ExcludeReplicasr   IncludeReplicasr   r   N)
r   r   r   r   r   r   r(   excludeReplicasincludeReplicasr   r   r    r!   r  r    s/    " **+<a@/**+<a@/r    r  c                       \ rS rSrSrSrg)DualRegionQuorumi  zKMessage type for a dual-region quorum. Currently this type has no
options.
r   NrL   r   r    r!   r  r    r   r    r  c                       \ rS rSrSrSrg)Emptyi  a  A generic empty message that you can re-use to avoid defining duplicated
empty messages in your APIs. A typical example is to use it as the request
or the response type of an API method. For instance: service Foo { rpc
Bar(google.protobuf.Empty) returns (google.protobuf.Empty); }
r   NrL   r   r    r!   r  r    s    r    r  c                   ^    \ rS rSrSr\R                  " S5      r\R                  " SSS9rSr	g)	rO  i  a[  Encryption configuration for a Cloud Spanner database.

Fields:
  kmsKeyName: The Cloud KMS key to be used for encrypting and decrypting the
    database. Values are of the form
    `projects//locations//keyRings//cryptoKeys/`.
  kmsKeyNames: Specifies the KMS configuration for one or more keys used to
    encrypt the database. Values are of the form
    `projects//locations//keyRings//cryptoKeys/`. The keys referenced by
    `kms_key_names` must fully cover all regions of the database's instance
    configuration. Some examples: * For regional (single-region) instance
    configurations, specify a regional location KMS key. * For multi-region
    instance configurations of type `GOOGLE_MANAGED`, either specify a
    multi-region location KMS key or multiple regional location KMS keys
    that cover all regions in the instance configuration. * For an instance
    configuration of type `USER_MANAGED`, specify only regional location KMS
    keys to cover each region in the instance configuration. Multi-region
    location KMS keys aren't supported for `USER_MANAGED` type instance
    configurations.
r   r   Tr$   r   N
r   r   r   r   r   r   r   r7  r8  r   r   r    r!   rO  rO    s+    * $$Q'*%%a$7+r    rO  c                       \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	\R                  " SS5      r\R                  " S5      rS	rg
)r   i  a  Encryption information for a Cloud Spanner database or backup.

Enums:
  EncryptionTypeValueValuesEnum: Output only. The type of encryption.

Fields:
  encryptionStatus: Output only. If present, the status of a recent
    encrypt/decrypt call on underlying data for this database or backup.
    Regardless of status, data is always encrypted at rest.
  encryptionType: Output only. The type of encryption.
  kmsKeyVersion: Output only. A Cloud KMS key version that is being used to
    protect the database or backup.
c                   $    \ rS rSrSrSrSrSrSrg),EncryptionInfo.EncryptionTypeValueValuesEnumi  a)  Output only. The type of encryption.

Values:
  TYPE_UNSPECIFIED: Encryption type was not specified, though data at rest
    remains encrypted.
  GOOGLE_DEFAULT_ENCRYPTION: The data is encrypted at rest with a key that
    is fully managed by Google. No key version or status will be
    populated. This is the default state.
  CUSTOMER_MANAGED_ENCRYPTION: The data is encrypted at rest with a key
    that is managed by the customer. The active version of the key.
    `kms_key_version` will be populated, and `encryption_status` may be
    populated.
r   r   r   r   N)	r   r   r   r   r   TYPE_UNSPECIFIEDr2  r3  r   r   r    r!   r4  r    s      !"#r    r4  r   r   r   r+   r   N)r   r   r   r   r   r   r   r4  r(   encryptionStatusr   r6  r   kmsKeyVersionr   r   r    r!   r   r     sO    $inn $$ ++Ha8&&'FJ.''*-r    r   c                   <    \ rS rSrSr\R                  " SSSS9rSrg)	r  i)  zAn ExcludeReplicas contains a repeated set of ReplicaSelection that
should be excluded from serving requests.

Fields:
  replicaSelections: The directed read replica selector.
ReplicaSelectionr   Tr$   r   N)	r   r   r   r   r   r   r(   replicaSelectionsr   r   r    r!   r  r  )  s      ,,-?TRr    r  c                       \ rS rSrSr\R                  " S5      r\R                  " SS5      r	\R                  " S5      r\R                  " SSS	S
9r\R                  " SS5      rSrg)ExecuteBatchDmlRequesti4  a  The request for ExecuteBatchDml.

Fields:
  lastStatements: Optional. If set to `true`, this request marks the end of
    the transaction. After these statements execute, you must commit or
    abort the transaction. Attempts to execute any other requests against
    this transaction (including reads and queries) are rejected. Setting
    this option might cause some error reporting to be deferred until commit
    time (for example, validation of unique constraints). Given this,
    successful execution of statements shouldn't be assumed until a
    subsequent `Commit` call completes successfully.
  requestOptions: Common options for this request.
  seqno: Required. A per-transaction sequence number used to identify this
    request. This field makes each request idempotent such that if the
    request is received multiple times, at most one succeeds. The sequence
    number must be monotonically increasing within the transaction. If a
    request arrives for the first time with an out-of-order sequence number,
    the transaction might be aborted. Replays of previously handled requests
    yield the same response as the first execution.
  statements: Required. The list of statements to execute in this batch.
    Statements are executed serially, such that the effects of statement `i`
    are visible to statement `i+1`. Each statement must be a DML statement.
    Execution stops at the first failed statement; the remaining statements
    are not executed. Callers must provide at least one statement.
  transaction: Required. The transaction to use. Must be a read-write
    transaction. To protect against replays, single-use transactions are not
    supported. The caller must either supply an existing transaction ID or
    begin a new transaction.
r   r   r   r+   	StatementrY   Tr$   TransactionSelectorrb   r   N)r   r   r   r   r   r   r;   lastStatementsr(   r   rc   seqno
statementstransactionr   r   r    r!   r  r  4  sc    < ))!,.))*:A>.

 
 
#%%%k1tD*&&'<a@+r    r  c                       \ rS rSrSr\R                  " SS5      r\R                  " SSSS9r\R                  " S	S
5      r	Sr
g)ExecuteBatchDmlResponseiZ  aF  The response for ExecuteBatchDml. Contains a list of ResultSet messages,
one for each DML statement that has successfully executed, in the same order
as the statements in the request. If a statement fails, the status in the
response body identifies the cause of the failure. To check for DML
statements that failed, use the following approach: 1. Check the status in
the response message. The google.rpc.Code enum value `OK` indicates that all
statements were executed successfully. 2. If the status was not `OK`, check
the number of result sets in the response. If the response contains `N`
ResultSet messages, then statement `N+1` in the request failed. Example 1: *
Request: 5 DML statements, all executed successfully. * Response: 5
ResultSet messages, with the status `OK`. Example 2: * Request: 5 DML
statements. The third statement has a syntax error. * Response: 2 ResultSet
messages, and a syntax error (`INVALID_ARGUMENT`) status. The number of
ResultSet messages indicates that the third statement failed, and the fourth
and fifth statements were not executed.

Fields:
  precommitToken: Optional. A precommit token is included if the read-write
    transaction is on a multiplexed session. Pass the precommit token with
    the highest sequence number from this transaction attempt should be
    passed to the Commit request for this transaction.
  resultSets: One ResultSet for each statement in the request that ran
    successfully, in the same order as the statements in the request. Each
    ResultSet does not contain any rows. The ResultSetStats in each
    ResultSet contain the number of rows modified by the statement. Only the
    first ResultSet in the response contains valid ResultSetMetadata.
  status: If all DML statements are executed successfully, the status is
    `OK`. Otherwise, the error status of the first failed statement.
r  r   	ResultSetr   Tr$   r   r+   r   N)r   r   r   r   r   r   r(   r	  
resultSetsr   r   r   r    r!   r  r  Z  sB    < ))*LaP.%%k1tD*!!(A.&r    r  c                      \ rS rSrSr " S S\R                  5      r\R                  " S5       " S S\R                  5      5       r\R                  " S5       " S S	\R                  5      5       r\R                  " S
5      r\R                  " SS5      r\R                  " S5      r\R                  " SS5      r\R                  " S	S5      r\R(                  " S5      r\R,                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R(                  " S5      r\R6                  " S5      r\R:                  " S5      r\R                  " SS5      rSr g)ExecuteSqlRequesti~  a  The request for ExecuteSql and ExecuteStreamingSql.

Enums:
  QueryModeValueValuesEnum: Used to control the amount of debugging
    information returned in ResultSetStats. If partition_token is set,
    query_mode can only be set to QueryMode.NORMAL.

Messages:
  ParamTypesValue: It isn't always possible for Cloud Spanner to infer the
    right SQL type from a JSON value. For example, values of type `BYTES`
    and values of type `STRING` both appear in params as JSON strings. In
    these cases, you can use `param_types` to specify the exact SQL type for
    some or all of the SQL statement parameters. See the definition of Type
    for more information about SQL types.
  ParamsValue: Parameter names and values that bind to placeholders in the
    SQL string. A parameter placeholder consists of the `@` character
    followed by the parameter name (for example, `@firstName`). Parameter
    names must conform to the naming requirements of identifiers as
    specified at https://cloud.google.com/spanner/docs/lexical#identifiers.
    Parameters can appear anywhere that a literal value is expected. The
    same parameter name can be used more than once, for example: `"WHERE id
    > @msg_id AND id < @msg_id + 100"` It's an error to execute a SQL
    statement with unbound parameters.

Fields:
  dataBoostEnabled: If this is for a partitioned query and this field is set
    to `true`, the request is executed with Spanner Data Boost independent
    compute resources. If the field is set to `true` but the request doesn't
    set `partition_token`, the API returns an `INVALID_ARGUMENT` error.
  directedReadOptions: Directed read options for this request.
  lastStatement: Optional. If set to `true`, this statement marks the end of
    the transaction. After this statement executes, you must commit or abort
    the transaction. Attempts to execute any other requests against this
    transaction (including reads and queries) are rejected. For DML
    statements, setting this option might cause some error reporting to be
    deferred until commit time (for example, validation of unique
    constraints). Given this, successful execution of a DML statement
    shouldn't be assumed until a subsequent `Commit` call completes
    successfully.
  paramTypes: It isn't always possible for Cloud Spanner to infer the right
    SQL type from a JSON value. For example, values of type `BYTES` and
    values of type `STRING` both appear in params as JSON strings. In these
    cases, you can use `param_types` to specify the exact SQL type for some
    or all of the SQL statement parameters. See the definition of Type for
    more information about SQL types.
  params: Parameter names and values that bind to placeholders in the SQL
    string. A parameter placeholder consists of the `@` character followed
    by the parameter name (for example, `@firstName`). Parameter names must
    conform to the naming requirements of identifiers as specified at
    https://cloud.google.com/spanner/docs/lexical#identifiers. Parameters
    can appear anywhere that a literal value is expected. The same parameter
    name can be used more than once, for example: `"WHERE id > @msg_id AND
    id < @msg_id + 100"` It's an error to execute a SQL statement with
    unbound parameters.
  partitionToken: If present, results are restricted to the specified
    partition previously created using `PartitionQuery`. There must be an
    exact match for the values of fields common to this message and the
    `PartitionQueryRequest` message used to create this `partition_token`.
  queryMode: Used to control the amount of debugging information returned in
    ResultSetStats. If partition_token is set, query_mode can only be set to
    QueryMode.NORMAL.
  queryOptions: Query optimizer configuration to use for the given query.
  requestOptions: Common options for this request.
  resumeToken: If this request is resuming a previously interrupted SQL
    statement execution, `resume_token` should be copied from the last
    PartialResultSet yielded before the interruption. Doing this enables the
    new SQL statement execution to resume where the last one left off. The
    rest of the request parameters must exactly match the request that
    yielded this token.
  seqno: A per-transaction sequence number used to identify this request.
    This field makes each request idempotent such that if the request is
    received multiple times, at most one succeeds. The sequence number must
    be monotonically increasing within the transaction. If a request arrives
    for the first time with an out-of-order sequence number, the transaction
    can be aborted. Replays of previously handled requests yield the same
    response as the first execution. Required for DML statements. Ignored
    for queries.
  sql: Required. The SQL string.
  transaction: The transaction to use. For queries, if none is provided, the
    default is a temporary read-only transaction with strong concurrency.
    Standard DML statements require a read-write transaction. To protect
    against replays, single-use transactions are not supported. The caller
    must either supply an existing transaction ID or begin a new
    transaction. Partitioned DML requires an existing Partitioned DML
    transaction ID.
c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
*ExecuteSqlRequest.QueryModeValueValuesEnumi  ad  Used to control the amount of debugging information returned in
ResultSetStats. If partition_token is set, query_mode can only be set to
QueryMode.NORMAL.

Values:
  NORMAL: The default mode. Only the statement results are returned.
  PLAN: This mode returns only the query plan, without any results or
    execution statistics information.
  PROFILE: This mode returns the query plan, overall execution statistics,
    operator level execution statistics along with the results. This has a
    performance overhead compared to the other modes. It isn't recommended
    to use this mode for production traffic.
  WITH_STATS: This mode returns the overall (but not operator-level)
    execution statistics along with the results.
  WITH_PLAN_AND_STATS: This mode returns the query plan, overall (but not
    operator-level) execution statistics along with the results.
r   r   r   r+   rY   r   N)r   r   r   r   r   NORMALPLANPROFILE
WITH_STATSWITH_PLAN_AND_STATSr   r   r    r!   QueryModeValueValuesEnumr    s#    " FDGJr    r  r   c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
!ExecuteSqlRequest.ParamTypesValuei  a   It isn't always possible for Cloud Spanner to infer the right SQL type
from a JSON value. For example, values of type `BYTES` and values of type
`STRING` both appear in params as JSON strings. In these cases, you can
use `param_types` to specify the exact SQL type for some or all of the SQL
statement parameters. See the definition of Type for more information
about SQL types.

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

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

Fields:
  key: Name of the additional property.
  value: A Type attribute.
r   r  r   r   Nr   r   r   r   r   r   r   r   r(   r   r   r   r    r!   r"   r    +    
 !!!$c$$VQ/er    r"   r   Tr$   r   Nr&   r   r    r!   ParamTypesValuer    2    	0Y.. 	0 %112FTXYr    r  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
ExecuteSqlRequest.ParamsValuei  a  Parameter names and values that bind to placeholders in the SQL
string. A parameter placeholder consists of the `@` character followed by
the parameter name (for example, `@firstName`). Parameter names must
conform to the naming requirements of identifiers as specified at
https://cloud.google.com/spanner/docs/lexical#identifiers. Parameters can
appear anywhere that a literal value is expected. The same parameter name
can be used more than once, for example: `"WHERE id > @msg_id AND id <
@msg_id + 100"` It's an error to execute a SQL statement with unbound
parameters.

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

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

Fields:
  key: Name of the additional property.
  value: A extra_types.JsonValue attribute.
r   extra_types.JsonValuer   r   Nr  r   r    r!   r"   r    ,    
 !!!$c$$%<a@er    r"   r   Tr$   r   Nr&   r   r    r!   ParamsValuer    s4    "	AY.. 	A %112FTXYr    r  r   r  r   r+   rY   rb   r   r   QueryOptionsr   r   r   r   r   r   r  r   r   N)!r   r   r   r   r   r   r   r  r   r,   r'   r  r  r;   dataBoostEnabledr(   directedReadOptionslastStatement
paramTypesparamsr.   partitionTokenr   	queryModequeryOptionsr   resumeTokenrc   r  r   sqlr  r   r   r    r!   r  r  ~  s`   Un 0 !!"89Z	)) Z :Z8 !!"89ZI%% Z :Z> ++A.!../DaH((+-%%&7;*!!-3&''*.!!"<a@)'':,))*:A>.$$R(+

 
 
$%b!#&&'<bA+r    r  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S5      r	\R                  " S5      r
Srg)	r   i:  aq  Represents a textual expression in the Common Expression Language (CEL)
syntax. CEL is a C-like expression language. The syntax and semantics of CEL
are documented at https://github.com/google/cel-spec. Example (Comparison):
title: "Summary size limit" description: "Determines if a summary is less
than 100 chars" expression: "document.summary.size() < 100" Example
(Equality): title: "Requestor is owner" description: "Determines if
requestor is the document owner" expression: "document.owner ==
request.auth.claims.email" Example (Logic): title: "Public documents"
description: "Determine whether the document should be publicly visible"
expression: "document.type != 'private' && document.type != 'internal'"
Example (Data Manipulation): title: "Notification string" description:
"Create a notification string with a timestamp." expression: "'New message
received at ' + string(document.create_time)" The exact variables and
functions that may be referenced within an expression are determined by the
service that evaluates it. See the service documentation for additional
information.

Fields:
  description: Optional. Description of the expression. This is a longer
    text which describes the expression, e.g. when hovered over it in a UI.
  expression: Textual representation of an expression in Common Expression
    Language syntax.
  location: Optional. String indicating the location of the expression for
    error reporting, e.g. a file name and a position in the file.
  title: Optional. Title for the expression, i.e. a short string describing
    its purpose. This can be used e.g. in UIs which allow to enter the
    expression.
r   r   r+   rY   r   N)r   r   r   r   r   r   r   description
expressionlocationtitler   r   r    r!   r   r   :  sI    : %%a(+$$Q'*""1%(



"%r    r   c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)Fieldi^  a  Message representing a single field of a struct.

Fields:
  name: The name of the field. For reads, this is the column name. For SQL
    queries, it is the column alias (e.g., `"Word"` in the query `"SELECT
    'hello' AS Word"`), or the column name (e.g., `"ColName"` in the query
    `"SELECT ColName FROM Table"`). Some columns might have an empty name
    (e.g., `"SELECT UPPER(ColName)"`). Note that a query result can contain
    multiple fields with the same name.
  type: The type of the field.
r   r  r   r   N)r   r   r   r   r   r   r   rB   r(   r   r   r   r    r!   r  r  ^  s+    
 
		q	!$				*$r    r  c                       \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	\R                  " S5      r\R                  " S5      rSrg	)
FreeInstanceMetadataio  a  Free instance specific metadata that is kept even after an instance has
been upgraded for tracking purposes.

Enums:
  ExpireBehaviorValueValuesEnum: Specifies the expiration behavior of a free
    instance. The default of ExpireBehavior is `REMOVE_AFTER_GRACE_PERIOD`.
    This can be modified during or after creation, and before expiration.

Fields:
  expireBehavior: Specifies the expiration behavior of a free instance. The
    default of ExpireBehavior is `REMOVE_AFTER_GRACE_PERIOD`. This can be
    modified during or after creation, and before expiration.
  expireTime: Output only. Timestamp after which the instance will either be
    upgraded or scheduled for deletion after a grace period. ExpireBehavior
    is used to choose between upgrading or scheduling the free instance for
    deletion. This timestamp is set during the creation of a free instance.
  upgradeTime: Output only. If present, the timestamp at which the free
    instance was upgraded to a provisioned instance.
c                   $    \ rS rSrSrSrSrSrSrg)2FreeInstanceMetadata.ExpireBehaviorValueValuesEnumi  a   Specifies the expiration behavior of a free instance. The default of
ExpireBehavior is `REMOVE_AFTER_GRACE_PERIOD`. This can be modified during
or after creation, and before expiration.

Values:
  EXPIRE_BEHAVIOR_UNSPECIFIED: Not specified.
  FREE_TO_PROVISIONED: When the free instance expires, upgrade the
    instance to a provisioned instance.
  REMOVE_AFTER_GRACE_PERIOD: When the free instance expires, disable the
    instance, and delete it after the grace period passes if it has not
    been upgraded.
r   r   r   r   N)	r   r   r   r   r   EXPIRE_BEHAVIOR_UNSPECIFIEDFREE_TO_PROVISIONEDREMOVE_AFTER_GRACE_PERIODr   r   r    r!   ExpireBehaviorValueValuesEnumr    s     #$ !r    r!  r   r   r+   r   N)r   r   r   r   r   r   r   r!  r   expireBehaviorr   r   upgradeTimer   r   r    r!   r  r  o  sL    ("inn "" &&'FJ.$$Q'*%%a(+r    r  c                       \ rS rSrSrSrg)r   i  zvThe specification for full backups. A full backup stores the entire
contents of the database at a given version time.
r   NrL   r   r    r!   r   r     r   r    r   c                   ^    \ rS rSrSr\R                  " S5      r\R                  " SSS9r	Sr
g)	GetDatabaseDdlResponsei  a  The response for GetDatabaseDdl.

Fields:
  protoDescriptors: Proto descriptors stored in the database. Contains a
    protobuf-serialized [google.protobuf.FileDescriptorSet](https://github.c
    om/protocolbuffers/protobuf/blob/main/src/google/protobuf/descriptor.pro
    to). For more details, see protobuffer [self
    description](https://developers.google.com/protocol-
    buffers/docs/techniques#self-description).
  statements: A list of formatted DDL statements defining the schema of the
    database specified in the request.
r   r   Tr$   r   N)r   r   r   r   r   r   r.   rR  r   r  r   r   r    r!   r&  r&    s,     ))!,$$Q6*r    r&  c                   >    \ rS rSrSr\R                  " SS5      rSrg)GetIamPolicyRequesti  zRequest message for `GetIamPolicy` method.

Fields:
  options: OPTIONAL: A `GetPolicyOptions` object for specifying options to
    `GetIamPolicy`.
GetPolicyOptionsr   r   N)	r   r   r   r   r   r   r(   r   r   r   r    r!   r(  r(    s     ""#5q9'r    r(  c                   b    \ rS rSrSr\R                  " S\R                  R                  S9r	Sr
g)r)  i  a]  Encapsulates settings provided to GetIamPolicy.

Fields:
  requestedPolicyVersion: Optional. The maximum policy version that will be
    used to format the policy. Valid values are 0, 1, and 3. Requests
    specifying an invalid value will be rejected. Requests for policies with
    any conditional role bindings must specify version 3. Policies with no
    conditional role bindings may specify any valid value or leave the field
    unset. The policy in the response might use the policy version that you
    specified, or it might use a lower policy version. For example, if you
    specify version 3, but the policy has no conditional role bindings, the
    response uses version 1. To learn which resources support conditions in
    their IAM policies, see the [IAM
    documentation](https://cloud.google.com/iam/help/conditions/resource-
    policies).
r   r`   r   N)r   r   r   r   r   r   rc   rd   re   requestedPolicyVersionr   r   r    r!   r)  r)    s(    " %11!Y=N=N=T=TUr    r)  c                   <    \ rS rSrSr\R                  " S5      rSrg)r   i  a  A heartbeat record is returned as a progress indicator, when there are
no data changes or any other partition record types in the change stream
partition.

Fields:
  timestamp: Indicates the timestamp at which the query has returned all the
    records in the change stream partition with timestamp <= heartbeat
    timestamp. The heartbeat timestamp will not be the same as the
    timestamps of other record types in the same partition.
r   r   N)	r   r   r   r   r   r   r   	timestampr   r   r    r!   r   r     s    	 ##A&)r    r   c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
r  i  a  An `IncludeReplicas` contains a repeated set of `ReplicaSelection` which
indicates the order in which replicas should be considered.

Fields:
  autoFailoverDisabled: If `true`, Spanner doesn't route requests to a
    replica outside the <`include_replicas` list when all of the specified
    replicas are unavailable or unhealthy. Default value is `false`.
  replicaSelections: The directed read replica selector.
r   r  r   Tr$   r   N)r   r   r   r   r   r   r;   autoFailoverDisabledr(   r  r   r   r    r!   r  r    s0     #//2,,-?TRr    r  c                       \ rS rSrSrSrg)r   i  ai  The specification for incremental backup chains. An incremental backup
stores the delta of changes between a previous backup and the database
contents at a given version time. An incremental backup chain consists of a
full backup and zero or more successive incremental backups. The first
backup created for an incremental backup chain is always a full backup.
r   NrL   r   r    r!   r   r     s    r    r   c                   ^    \ rS rSrSr\R                  " SSS9r\R                  " S5      r	Sr
g)	IndexAdvicei  ao  Recommendation to add new indexes to run queries more efficiently.

Fields:
  ddl: Optional. DDL statements to add new indexes that will improve the
    query.
  improvementFactor: Optional. Estimated latency improvement factor. For
    example if the query currently takes 500 ms to run and the estimated
    latency with new indexes is 100 ms this field will be 5.
r   Tr$   r   r   N)r   r   r   r   r   r   r   ddlr)  improvementFactorr   r   r    r!   r2  r2    s,     	a$/#**1-r    r2  c                       \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " SS5      rSrg)	IndexedHotKeyi
	  a~  A message representing a (sparse) collection of hot keys for specific
key buckets.

Messages:
  SparseHotKeysValue: A (sparse) mapping from key bucket index to the index
    of the specific hot row key for that key bucket. The index of the hot
    row key can be translated to the actual row key via the
    ScanData.VisualizationData.indexed_keys repeated field.

Fields:
  sparseHotKeys: A (sparse) mapping from key bucket index to the index of
    the specific hot row key for that key bucket. The index of the hot row
    key can be translated to the actual row key via the
    ScanData.VisualizationData.indexed_keys repeated field.
r   c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
 IndexedHotKey.SparseHotKeysValuei	  a  A (sparse) mapping from key bucket index to the index of the specific
hot row key for that key bucket. The index of the hot row key can be
translated to the actual row key via the
ScanData.VisualizationData.indexed_keys repeated field.

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

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

Fields:
  key: Name of the additional property.
  value: A integer attribute.
r   r   r`   r   Nr   r   r   r   r   r   r   r   rc   rd   re   r   r   r   r    r!   r"   r:  *	  7    
 !!!$c$$Q	0A0A0G0GHer    r"   r   Tr$   r   Nr&   r   r    r!   SparseHotKeysValuer8  	  s4    	IY.. 	I %112FTXYr    r=  r   r   N)r   r   r   r   r   r   r,   r   r'   r=  r(   sparseHotKeysr   r   r    r!   r6  r6  
	  sL      !!"89Z9,, Z :Z6 (()=qA-r    r6  c                       \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " SS5      rSrg)	IndexedKeyRangeInfosi:	  aA  A message representing a (sparse) collection of KeyRangeInfos for
specific key buckets.

Messages:
  KeyRangeInfosValue: A (sparse) mapping from key bucket index to the
    KeyRangeInfos for that key bucket.

Fields:
  keyRangeInfos: A (sparse) mapping from key bucket index to the
    KeyRangeInfos for that key bucket.
r   c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
'IndexedKeyRangeInfos.KeyRangeInfosValueiG	  a  A (sparse) mapping from key bucket index to the KeyRangeInfos for that
key bucket.

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

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

Fields:
  key: Name of the additional property.
  value: A KeyRangeInfos attribute.
r   KeyRangeInfosr   r   Nr  r   r    r!   r"   rD  T	  +    
 !!!$c$$_a8er    r"   r   Tr$   r   Nr&   r   r    r!   KeyRangeInfosValuerB  G	  2    		9Y.. 	9 %112FTXYr    rG  r   r   N)r   r   r   r   r   r   r,   r   r'   rG  r(   keyRangeInfosr   r   r    r!   r@  r@  :	  sL    
 !!"89Z9,, Z :Z2 (()=qA-r    r@  c                      \ rS rSrSr " S S\R                  5      r " S S\R                  5      r " S S\R                  5      r	 " S	 S
\R                  5      r
 " S S\R                  5      r\R                  " S5       " S S\R                  5      5       r\R                  " S5       " S S\R                  5      5       r\R"                  " SS5      r\R&                  " S5      r\R&                  " S5      r\R,                  " SS5      r\R,                  " SS5      r\R&                  " S5      r\R,                  " SS5      r\R&                  " SSS9r\R"                  " SS5      r\R,                  " S
S5      r\R"                  " SS 5      r\R&                  " S!5      r\R@                  " S"\RB                  RD                  S#9r#\R@                  " S$\RB                  RD                  S#9r$\R"                  " S%S&SS9r%\R&                  " S'5      r&\R,                  " SS(5      r'\R"                  " SS)5      r(\R&                  " S*5      r)S+r*g,)-rh  id	  a"  An isolated set of Cloud Spanner resources on which databases can be
hosted.

Enums:
  DefaultBackupScheduleTypeValueValuesEnum: Optional. Controls the default
    backup schedule behavior for new databases within the instance. By
    default, a backup schedule is created automatically when a new database
    is created in a new instance. Note that the `AUTOMATIC` value isn't
    permitted for free instances, as backups and backup schedules aren't
    supported for free instances. In the `GetInstance` or `ListInstances`
    response, if the value of `default_backup_schedule_type` isn't set, or
    set to `NONE`, Spanner doesn't create a default backup schedule for new
    databases in the instance.
  DefaultStorageTypeValueValuesEnum: The `StorageType` of the current
    instance. If unspecified, it will default to the first StorageType in
    the list of allowed_storage_types in the `InstanceConfig` for this
    instance.
  EditionValueValuesEnum: Optional. The `Edition` of the current instance.
  InstanceTypeValueValuesEnum: The `InstanceType` of the current instance.
  StateValueValuesEnum: Output only. The current instance state. For
    CreateInstance, the state must be either omitted or set to `CREATING`.
    For UpdateInstance, the state must be either omitted or set to `READY`.

Messages:
  LabelsValue: Cloud Labels are a flexible and lightweight mechanism for
    organizing cloud resources into groups that reflect a customer's
    organizational needs and deployment strategies. Cloud Labels can be used
    to filter collections of resources. They can be used to control how
    resource metrics are aggregated. And they can be used as arguments to
    policy management rules (e.g. route, firewall, load balancing, etc.). *
    Label keys must be between 1 and 63 characters long and must conform to
    the following regular expression: `a-z{0,62}`. * Label values must be
    between 0 and 63 characters long and must conform to the regular
    expression `[a-z0-9_-]{0,63}`. * No more than 64 labels can be
    associated with a given resource. See https://goo.gl/xmQnxf for more
    information on and examples of labels. If you plan to use labels in your
    own code, please note that additional characters may be allowed in the
    future. And so you are advised to use an internal label representation,
    such as JSON, which doesn't rely upon specific characters being
    disallowed. For example, representing labels as the string: name + "_" +
    value would prove problematic if we were to allow "_" in a future
    release.
  TagsValue: Optional. Tag keys/values directly bound to this resource. For
    example: "123/environment": "prod", "123/costCenter": "marketing"

Fields:
  autoscalingConfig: Optional. The autoscaling configuration. Autoscaling is
    enabled if this field is set. When autoscaling is enabled, node_count
    and processing_units are treated as OUTPUT_ONLY fields and reflect the
    current compute capacity allocated to the instance.
  config: Required. The name of the instance's configuration. Values are of
    the form `projects//instanceConfigs/`. See also InstanceConfig and
    ListInstanceConfigs.
  createTime: Output only. The time at which the instance was created.
  defaultBackupScheduleType: Optional. Controls the default backup schedule
    behavior for new databases within the instance. By default, a backup
    schedule is created automatically when a new database is created in a
    new instance. Note that the `AUTOMATIC` value isn't permitted for free
    instances, as backups and backup schedules aren't supported for free
    instances. In the `GetInstance` or `ListInstances` response, if the
    value of `default_backup_schedule_type` isn't set, or set to `NONE`,
    Spanner doesn't create a default backup schedule for new databases in
    the instance.
  defaultStorageType: The `StorageType` of the current instance. If
    unspecified, it will default to the first StorageType in the list of
    allowed_storage_types in the `InstanceConfig` for this instance.
  displayName: Required. The descriptive name for this instance as it
    appears in UIs. Must be unique per project and between 4 and 30
    characters in length.
  edition: Optional. The `Edition` of the current instance.
  endpointUris: Deprecated. This field is not populated.
  freeInstanceMetadata: Free instance metadata. Only populated for free
    instances.
  instanceType: The `InstanceType` of the current instance.
  labels: Cloud Labels are a flexible and lightweight mechanism for
    organizing cloud resources into groups that reflect a customer's
    organizational needs and deployment strategies. Cloud Labels can be used
    to filter collections of resources. They can be used to control how
    resource metrics are aggregated. And they can be used as arguments to
    policy management rules (e.g. route, firewall, load balancing, etc.). *
    Label keys must be between 1 and 63 characters long and must conform to
    the following regular expression: `a-z{0,62}`. * Label values must be
    between 0 and 63 characters long and must conform to the regular
    expression `[a-z0-9_-]{0,63}`. * No more than 64 labels can be
    associated with a given resource. See https://goo.gl/xmQnxf for more
    information on and examples of labels. If you plan to use labels in your
    own code, please note that additional characters may be allowed in the
    future. And so you are advised to use an internal label representation,
    such as JSON, which doesn't rely upon specific characters being
    disallowed. For example, representing labels as the string: name + "_" +
    value would prove problematic if we were to allow "_" in a future
    release.
  name: Required. A unique identifier for the instance, which cannot be
    changed after the instance is created. Values are of the form
    `projects//instances/a-z*[a-z0-9]`. The final segment of the name must
    be between 2 and 64 characters in length.
  nodeCount: The number of nodes allocated to this instance. At most, one of
    either `node_count` or `processing_units` should be present in the
    message. Users can set the `node_count` field to specify the target
    number of nodes allocated to the instance. If autoscaling is enabled,
    `node_count` is treated as an `OUTPUT_ONLY` field and reflects the
    current number of nodes allocated to the instance. This might be zero in
    API responses for instances that are not yet in the `READY` state. If
    the instance has varying node count across replicas (achieved by setting
    `asymmetric_autoscaling_options` in the autoscaling configuration), the
    `node_count` set here is the maximum node count across all replicas. For
    more information, see [Compute capacity, nodes, and processing
    units](https://cloud.google.com/spanner/docs/compute-capacity).
  processingUnits: The number of processing units allocated to this
    instance. At most, one of either `processing_units` or `node_count`
    should be present in the message. Users can set the `processing_units`
    field to specify the target number of processing units allocated to the
    instance. If autoscaling is enabled, `processing_units` is treated as an
    `OUTPUT_ONLY` field and reflects the current number of processing units
    allocated to the instance. This might be zero in API responses for
    instances that are not yet in the `READY` state. If the instance has
    varying processing units per replica (achieved by setting
    `asymmetric_autoscaling_options` in the autoscaling configuration), the
    `processing_units` set here is the maximum processing units across all
    replicas. For more information, see [Compute capacity, nodes and
    processing units](https://cloud.google.com/spanner/docs/compute-
    capacity).
  replicaComputeCapacity: Output only. Lists the compute capacity per
    ReplicaSelection. A replica selection identifies a set of replicas with
    common properties. Replicas identified by a ReplicaSelection are scaled
    with the same compute capacity.
  ssdCache: Optional. The name of the SSD cache to be used with this
    `Instance`. SSD cache can reduce the instance's disk I/O requirements.
    Applicable only when `StorageType` is `HDD`. `SsdCache` should exist
    under instance's `config`. If unspecified, no SSD cache will be
    associated with this `Instance`. Values are of the form
    `projects//instanceConfigs//ssdCaches/`.
  state: Output only. The current instance state. For CreateInstance, the
    state must be either omitted or set to `CREATING`. For UpdateInstance,
    the state must be either omitted or set to `READY`.
  tags: Optional. Tag keys/values directly bound to this resource. For
    example: "123/environment": "prod", "123/costCenter": "marketing"
  updateTime: Output only. The time at which the instance was most recently
    updated.
c                   $    \ rS rSrSrSrSrSrSrg)1Instance.DefaultBackupScheduleTypeValueValuesEnumi	  a  Optional. Controls the default backup schedule behavior for new
databases within the instance. By default, a backup schedule is created
automatically when a new database is created in a new instance. Note that
the `AUTOMATIC` value isn't permitted for free instances, as backups and
backup schedules aren't supported for free instances. In the `GetInstance`
or `ListInstances` response, if the value of
`default_backup_schedule_type` isn't set, or set to `NONE`, Spanner
doesn't create a default backup schedule for new databases in the
instance.

Values:
  DEFAULT_BACKUP_SCHEDULE_TYPE_UNSPECIFIED: Not specified.
  NONE: A default backup schedule isn't created automatically when a new
    database is created in the instance.
  AUTOMATIC: A default backup schedule is created automatically when a new
    database is created in the instance. The default backup schedule
    creates a full backup every 24 hours. These full backups are retained
    for 7 days. You can edit or delete the default backup schedule once
    it's created.
r   r   r   r   N)	r   r   r   r   r   (DEFAULT_BACKUP_SCHEDULE_TYPE_UNSPECIFIEDNONE	AUTOMATICr   r   r    r!   (DefaultBackupScheduleTypeValueValuesEnumrL  	  s    ( 01,DIr    rP  c                   $    \ rS rSrSrSrSrSrSrg)*Instance.DefaultStorageTypeValueValuesEnumi
  aT  The `StorageType` of the current instance. If unspecified, it will
default to the first StorageType in the list of allowed_storage_types in
the `InstanceConfig` for this instance.

Values:
  STORAGE_TYPE_UNSPECIFIED: Storage type not specified.
  SSD: Flash (SSD) storage should be used.
  HDD: Magnetic drive (HDD) storage should be used.
r   r   r   r   N	r   r   r   r   r   STORAGE_TYPE_UNSPECIFIEDSSDHDDr   r   r    r!   !DefaultStorageTypeValueValuesEnumrR  
  s      !
C
Cr    rW  c                   (    \ rS rSrSrSrSrSrSrSr	g)	Instance.EditionValueValuesEnumi
  zOptional. The `Edition` of the current instance.

Values:
  EDITION_UNSPECIFIED: Edition not specified.
  STANDARD: Standard edition.
  ENTERPRISE: Enterprise edition.
  ENTERPRISE_PLUS: Enterprise Plus edition.
r   r   r   r+   r   N)
r   r   r   r   r   EDITION_UNSPECIFIEDSTANDARD
ENTERPRISEENTERPRISE_PLUSr   r   r    r!   EditionValueValuesEnumrY  
  s     HJOr    r^  c                   $    \ rS rSrSrSrSrSrSrg)$Instance.InstanceTypeValueValuesEnumi'
  a  The `InstanceType` of the current instance.

Values:
  INSTANCE_TYPE_UNSPECIFIED: Not specified.
  PROVISIONED: Provisioned instances have dedicated resources, standard
    usage limits and support.
  FREE_INSTANCE: Free instances provide no guarantee for dedicated
    resources, [node_count, processing_units] should be 0. They come with
    stricter usage limits and limited support.
r   r   r   r   N)	r   r   r   r   r   INSTANCE_TYPE_UNSPECIFIEDPROVISIONEDFREE_INSTANCEr   r   r    r!   InstanceTypeValueValuesEnumr`  '
  s    	 !"KMr    rd  c                   $    \ rS rSrSrSrSrSrSrg)Instance.StateValueValuesEnumi6
  a  Output only. The current instance state. For CreateInstance, the state
must be either omitted or set to `CREATING`. For UpdateInstance, the state
must be either omitted or set to `READY`.

Values:
  STATE_UNSPECIFIED: Not specified.
  CREATING: The instance is still being created. Resources may not be
    available yet, and operations such as database creation may not work.
  READY: The instance is fully created and ready to do work such as
    creating databases.
r   r   r   r   Nr   r   r    r!   r   rf  6
  s    
 HEr    r   r   c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
Instance.LabelsValueiF
  2  Cloud Labels are a flexible and lightweight mechanism for organizing
cloud resources into groups that reflect a customer's organizational needs
and deployment strategies. Cloud Labels can be used to filter collections
of resources. They can be used to control how resource metrics are
aggregated. And they can be used as arguments to policy management rules
(e.g. route, firewall, load balancing, etc.). * Label keys must be between
1 and 63 characters long and must conform to the following regular
expression: `a-z{0,62}`. * Label values must be between 0 and 63
characters long and must conform to the regular expression
`[a-z0-9_-]{0,63}`. * No more than 64 labels can be associated with a
given resource. See https://goo.gl/xmQnxf for more information on and
examples of labels. If you plan to use labels in your own code, please
note that additional characters may be allowed in the future. And so you
are advised to use an internal label representation, such as JSON, which
doesn't rely upon specific characters being disallowed. For example,
representing labels as the string: name + "_" + value would prove
problematic if we were to allow "_" in a future release.

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

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

Fields:
  key: Name of the additional property.
  value: A string attribute.
r   r   r   Nr   r   r    r!   r"   rk  a
  r#   r    r"   r   Tr$   r   Nr&   r   r    r!   LabelsValuerh  F
  2    2	'Y.. 	' %112FTXYr    rm  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
Instance.TagsValuein
  a  Optional. Tag keys/values directly bound to this resource. For
example: "123/environment": "prod", "123/costCenter": "marketing"

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

Fields:
  additionalProperties: Additional properties of type TagsValue
c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)%Instance.TagsValue.AdditionalPropertyiz
  rz  r   r   r   Nr   r   r    r!   r"   rr  z
  r#   r    r"   r   Tr$   r   Nr&   r   r    r!   r{  rp  n
  r*   r    r{  rU   r   r   r+   rY   rb   r   r   r   Tr$   r  r   r   r   r   r   r`   r   ReplicaComputeCapacityr   r   r   r
   r   r   N)+r   r   r   r   r   r   r   rP  rW  r^  rd  r   r   r,   r'   rm  r{  r(   autoscalingConfigr   configr   r   defaultBackupScheduleTypedefaultStorageTypedisplayNameeditionendpointUrisfreeInstanceMetadatainstanceTypelabelsrB   rc   rd   re   	nodeCountprocessingUnitsreplicaComputeCapacityssdCacher   r}  r   r   r   r    r!   rh  rh  d	  s0   KZ 2).. y~~ INN Y^^   !!"89%ZI%% %Z :%ZN !!"89Z)## Z :Z0  ,,-@!D  #&$$Q'*'112\^_` **+NPQR%%a(+ 8!<'&&q48,"//0FJ$$%BBG,!!-4&			r	"$$$R1B1B1H1HI)**2y7H7H7N7NO/$112JBY]^""2&(


4b
9%			R	0$$$R(*r    rh  c                   b   \ rS rSrSr " S S\R                  5      r " S S\R                  5      r " S S\R                  5      r	 " S	 S
\R                  5      r
 " S S\R                  5      r\R                  " S5       " S S\R                  5      5       r\R                   " SSSS9r\R$                  " S5      r\R                   " SS5      r\R$                  " S5      r\R$                  " S5      r\R                   " SS5      r\R0                  " SS5      r\R$                  " SSS9r\R$                  " S5      r\R0                  " SSSS9r\R                   " S
S5      r\R<                  " S5      r\R0                  " SSSS9r \R                   " SS 5      r!\RD                  " S!5      r#S"r$g#)$rU  i
  a  A possible configuration for a Cloud Spanner instance. Configurations
define the geographic placement of nodes and their replication.

Enums:
  AllowedStorageTypesValueListEntryValuesEnum:
  ConfigTypeValueValuesEnum: Output only. Whether this instance
    configuration is a Google-managed or user-managed configuration.
  FreeInstanceAvailabilityValueValuesEnum: Output only. Describes whether
    free instances are available to be created in this instance
    configuration.
  QuorumTypeValueValuesEnum: Output only. The `QuorumType` of the instance
    configuration.
  StateValueValuesEnum: Output only. The current instance configuration
    state. Applicable only for `USER_MANAGED` configurations.

Messages:
  LabelsValue: Cloud Labels are a flexible and lightweight mechanism for
    organizing cloud resources into groups that reflect a customer's
    organizational needs and deployment strategies. Cloud Labels can be used
    to filter collections of resources. They can be used to control how
    resource metrics are aggregated. And they can be used as arguments to
    policy management rules (e.g. route, firewall, load balancing, etc.). *
    Label keys must be between 1 and 63 characters long and must conform to
    the following regular expression: `a-z{0,62}`. * Label values must be
    between 0 and 63 characters long and must conform to the regular
    expression `[a-z0-9_-]{0,63}`. * No more than 64 labels can be
    associated with a given resource. See https://goo.gl/xmQnxf for more
    information on and examples of labels. If you plan to use labels in your
    own code, please note that additional characters may be allowed in the
    future. Therefore, you are advised to use an internal label
    representation, such as JSON, which doesn't rely upon specific
    characters being disallowed. For example, representing labels as the
    string: name + "_" + value would prove problematic if we were to allow
    "_" in a future release.

Fields:
  allowedStorageTypes: Output only. The allowed storage types for this
    configuration. The first storage type is considered the default storage
    type for any instance that has its default_storage_type field unset or
    set to STORAGE_TYPE_UNSPECIFIED.
  baseConfig: Base configuration name, e.g. projects//instanceConfigs/nam3,
    based on which this configuration is created. Only set for user-managed
    configurations. `base_config` must refer to a configuration of type
    `GOOGLE_MANAGED` in the same project as this configuration.
  configType: Output only. Whether this instance configuration is a Google-
    managed or user-managed configuration.
  displayName: The name of this instance configuration as it appears in UIs.
  etag: etag is used for optimistic concurrency control as a way to help
    prevent simultaneous updates of a instance configuration from
    overwriting each other. It is strongly suggested that systems make use
    of the etag in the read-modify-write cycle to perform instance
    configuration updates in order to avoid race conditions: An etag is
    returned in the response which contains instance configurations, and
    systems are expected to put that etag in the request to update instance
    configuration to ensure that their change is applied to the same version
    of the instance configuration. If no etag is provided in the call to
    update the instance configuration, then the existing instance
    configuration is overwritten blindly.
  freeInstanceAvailability: Output only. Describes whether free instances
    are available to be created in this instance configuration.
  labels: Cloud Labels are a flexible and lightweight mechanism for
    organizing cloud resources into groups that reflect a customer's
    organizational needs and deployment strategies. Cloud Labels can be used
    to filter collections of resources. They can be used to control how
    resource metrics are aggregated. And they can be used as arguments to
    policy management rules (e.g. route, firewall, load balancing, etc.). *
    Label keys must be between 1 and 63 characters long and must conform to
    the following regular expression: `a-z{0,62}`. * Label values must be
    between 0 and 63 characters long and must conform to the regular
    expression `[a-z0-9_-]{0,63}`. * No more than 64 labels can be
    associated with a given resource. See https://goo.gl/xmQnxf for more
    information on and examples of labels. If you plan to use labels in your
    own code, please note that additional characters may be allowed in the
    future. Therefore, you are advised to use an internal label
    representation, such as JSON, which doesn't rely upon specific
    characters being disallowed. For example, representing labels as the
    string: name + "_" + value would prove problematic if we were to allow
    "_" in a future release.
  leaderOptions: Allowed values of the "default_leader" schema option for
    databases in instances that use this instance configuration.
  name: A unique identifier for the instance configuration. Values are of
    the form `projects//instanceConfigs/a-z*`. User instance configuration
    must start with `custom-`.
  optionalReplicas: Output only. The available optional replicas to choose
    from for user-managed configurations. Populated for Google-managed
    configurations.
  quorumType: Output only. The `QuorumType` of the instance configuration.
  reconciling: Output only. If true, the instance configuration is being
    created or updated. If false, there are no ongoing operations for the
    instance configuration.
  replicas: The geographic placement of nodes in this instance configuration
    and their replication properties. To create user-managed configurations,
    input `replicas` must include all replicas in `replicas` of the
    `base_config` and include one or more replicas in the
    `optional_replicas` of the `base_config`.
  state: Output only. The current instance configuration state. Applicable
    only for `USER_MANAGED` configurations.
  storageLimitPerProcessingUnit: Output only. The storage limit in bytes per
    processing unit.
c                   $    \ rS rSrSrSrSrSrSrg):InstanceConfig.AllowedStorageTypesValueListEntryValuesEnumi  zAllowedStorageTypesValueListEntryValuesEnum enum type.

Values:
  STORAGE_TYPE_UNSPECIFIED: Storage type not specified.
  SSD: Flash (SSD) storage should be used.
  HDD: Magnetic drive (HDD) storage should be used.
r   r   r   r   NrS  r   r    r!   +AllowedStorageTypesValueListEntryValuesEnumr    s      !
C
Cr    r  c                   $    \ rS rSrSrSrSrSrSrg)(InstanceConfig.ConfigTypeValueValuesEnumi  zOutput only. Whether this instance configuration is a Google-managed
or user-managed configuration.

Values:
  TYPE_UNSPECIFIED: Unspecified.
  GOOGLE_MANAGED: Google-managed configuration.
  USER_MANAGED: User-managed configuration.
r   r   r   r   N)	r   r   r   r   r   r  GOOGLE_MANAGEDUSER_MANAGEDr   r   r    r!   ConfigTypeValueValuesEnumr    s     NLr    r  c                   ,    \ rS rSrSrSrSrSrSrSr	Sr
g	)
6InstanceConfig.FreeInstanceAvailabilityValueValuesEnumi  a  Output only. Describes whether free instances are available to be
created in this instance configuration.

Values:
  FREE_INSTANCE_AVAILABILITY_UNSPECIFIED: Not specified.
  AVAILABLE: Indicates that free instances are available to be created in
    this instance configuration.
  UNSUPPORTED: Indicates that free instances are not supported in this
    instance configuration.
  DISABLED: Indicates that free instances are currently not available to
    be created in this instance configuration.
  QUOTA_EXCEEDED: Indicates that additional free instances cannot be
    created in this instance configuration because the project has reached
    its limit of free instances.
r   r   r   r+   rY   r   N)r   r   r   r   r   &FREE_INSTANCE_AVAILABILITY_UNSPECIFIED	AVAILABLEUNSUPPORTEDDISABLEDQUOTA_EXCEEDEDr   r   r    r!   'FreeInstanceAvailabilityValueValuesEnumr    s#     ./*IKHNr    r  c                   (    \ rS rSrSrSrSrSrSrSr	g)	(InstanceConfig.QuorumTypeValueValuesEnumi1  a  Output only. The `QuorumType` of the instance configuration.

Values:
  QUORUM_TYPE_UNSPECIFIED: Quorum type not specified.
  REGION: An instance configuration tagged with `REGION` quorum type forms
    a write quorum in a single region.
  DUAL_REGION: An instance configuration tagged with the `DUAL_REGION`
    quorum type forms a write quorum with exactly two read-write regions
    in a multi-region configuration. This instance configuration requires
    failover in the event of regional failures.
  MULTI_REGION: An instance configuration tagged with the `MULTI_REGION`
    quorum type forms a write quorum from replicas that are spread across
    more than one region in a multi-region configuration.
r   r   r   r+   r   N)
r   r   r   r   r   QUORUM_TYPE_UNSPECIFIEDREGIONDUAL_REGIONMULTI_REGIONr   r   r    r!   QuorumTypeValueValuesEnumr  1  s      FKLr    r  c                   $    \ rS rSrSrSrSrSrSrg)#InstanceConfig.StateValueValuesEnumiE  a9  Output only. The current instance configuration state. Applicable only
for `USER_MANAGED` configurations.

Values:
  STATE_UNSPECIFIED: Not specified.
  CREATING: The instance configuration is still being created.
  READY: The instance configuration is fully created and ready to be used
    to create instances.
r   r   r   r   Nr   r   r    r!   r   r  E       HEr    r   r   c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
InstanceConfig.LabelsValueiS  a6  Cloud Labels are a flexible and lightweight mechanism for organizing
cloud resources into groups that reflect a customer's organizational needs
and deployment strategies. Cloud Labels can be used to filter collections
of resources. They can be used to control how resource metrics are
aggregated. And they can be used as arguments to policy management rules
(e.g. route, firewall, load balancing, etc.). * Label keys must be between
1 and 63 characters long and must conform to the following regular
expression: `a-z{0,62}`. * Label values must be between 0 and 63
characters long and must conform to the regular expression
`[a-z0-9_-]{0,63}`. * No more than 64 labels can be associated with a
given resource. See https://goo.gl/xmQnxf for more information on and
examples of labels. If you plan to use labels in your own code, please
note that additional characters may be allowed in the future. Therefore,
you are advised to use an internal label representation, such as JSON,
which doesn't rely upon specific characters being disallowed. For example,
representing labels as the string: name + "_" + value would prove
problematic if we were to allow "_" in a future release.

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

Fields:
  additionalProperties: Additional properties of type LabelsValue
c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)-InstanceConfig.LabelsValue.AdditionalPropertyin  rl  r   r   r   Nr   r   r    r!   r"   r  n  r#   r    r"   r   Tr$   r   Nr&   r   r    r!   rm  r  S  rn  r    rm  r   Tr$   r   r+   rY   rb   r   r   r   r   ReplicaInfor   r   r   r   r   r   r   N)%r   r   r   r   r   r   r   r  r  r  r  r   r   r,   r'   rm  r   allowedStorageTypesr   
baseConfig
configTyperx  r   freeInstanceAvailabilityr(   r}  leaderOptionsrB   optionalReplicasr   r;   r  replicasr   rc   storageLimitPerProcessingUnitr   r   r    r!   rU  rU  
  s   cJ
INN 
).. 	 ,).. (Y^^  !!"89%ZI%% %Z :%ZN "++,Y[\gkl$$Q'*""#>B*%%a(+			q	!$&001Z\]^!!-3&''D9-			q	!$++M2M""#>C*&&r*+##M2E(


4b
9%"+"8"8"<r    rU  c                   ^    \ rS rSrSr\R                  " S5      r\R                  " SSS9rSr	g)	r  i  a  Encryption configuration for a Cloud Spanner database.

Fields:
  kmsKeyName: Optional. This field is maintained for backwards
    compatibility. For new callers, we recommend using `kms_key_names` to
    specify the KMS key. Only use `kms_key_name` if the location of the KMS
    key matches the database instance's configuration (location) exactly.
    For example, if the KMS location is in `us-central1` or `nam3`, then the
    database instance must also be in `us-central1` or `nam3`. The Cloud KMS
    key that is used to encrypt and decrypt the restored database. Values
    are of the form `projects//locations//keyRings//cryptoKeys/`.
  kmsKeyNames: Optional. Specifies the KMS configuration for one or more
    keys used to encrypt the database. Values are of the form
    `projects//locations//keyRings//cryptoKeys/`. The keys referenced by
    `kms_key_names` must fully cover all regions of the database's instance
    configuration. Some examples: * For regional (single-region) instance
    configurations, specify a regional location KMS key. * For multi-region
    instance configurations of type `GOOGLE_MANAGED`, either specify a
    multi-region location KMS key or multiple regional location KMS keys
    that cover all regions in the instance configuration. * For an instance
    configuration of type `USER_MANAGED`, specify only regional location KMS
    keys to cover each region in the instance configuration. Multi-region
    location KMS keys aren't supported for `USER_MANAGED` type instance
    configurations.
r   r   Tr$   r   Nr  r   r    r!   r  r    s+    4 $$Q'*%%a$7+r    r  c                       \ rS rSrSr\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " S5      rSrg)	rV  i  aW  Encapsulates progress related information for a Cloud Spanner long
running instance operations.

Fields:
  endTime: If set, the time at which this operation failed or was completed
    successfully.
  progressPercent: Percent completion of the operation. Values are between 0
    and 100 inclusive.
  startTime: Time the request was received.
r   r   r`   r+   r   Nr   r   r   r   r   r   r   r   rc   rd   re   progressPercentr   r   r   r    r!   rV  rV    G    	 !!!$'**1i6G6G6M6MN/##A&)r    rV  c                   >   \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	\R                  " S5      r\R                  " S5      r\R                  " S	5      r\R                  " S
5      r\R                  " S5      r\R                   " S\R"                  R$                  S9r\R                   " S\R"                  R$                  S9r\R                  " SSS9r\R                  " SSS9r\R.                  " SS5      r\R                  " S5      rSrg)ro  i  a  An isolated set of Cloud Spanner resources that databases can define
placements on.

Enums:
  StateValueValuesEnum: Output only. The current instance partition state.

Fields:
  autoscalingConfig: Optional. The autoscaling configuration. Autoscaling is
    enabled if this field is set. When autoscaling is enabled, fields in
    compute_capacity are treated as OUTPUT_ONLY fields and reflect the
    current compute capacity allocated to the instance partition.
  config: Required. The name of the instance partition's configuration.
    Values are of the form `projects//instanceConfigs/`. See also
    InstanceConfig and ListInstanceConfigs.
  createTime: Output only. The time at which the instance partition was
    created.
  displayName: Required. The descriptive name for this instance partition as
    it appears in UIs. Must be unique per project and between 4 and 30
    characters in length.
  etag: Used for optimistic concurrency control as a way to help prevent
    simultaneous updates of a instance partition from overwriting each
    other. It is strongly suggested that systems make use of the etag in the
    read-modify-write cycle to perform instance partition updates in order
    to avoid race conditions: An etag is returned in the response which
    contains instance partitions, and systems are expected to put that etag
    in the request to update instance partitions to ensure that their change
    will be applied to the same version of the instance partition. If no
    etag is provided in the call to update instance partition, then the
    existing instance partition is overwritten blindly.
  name: Required. A unique identifier for the instance partition. Values are
    of the form `projects//instances//instancePartitions/a-z*[a-z0-9]`. The
    final segment of the name must be between 2 and 64 characters in length.
    An instance partition's name cannot be changed after the instance
    partition is created.
  nodeCount: The number of nodes allocated to this instance partition. Users
    can set the `node_count` field to specify the target number of nodes
    allocated to the instance partition. This may be zero in API responses
    for instance partitions that are not yet in state `READY`.
  processingUnits: The number of processing units allocated to this instance
    partition. Users can set the `processing_units` field to specify the
    target number of processing units allocated to the instance partition.
    This might be zero in API responses for instance partitions that are not
    yet in the `READY` state.
  referencingBackups: Output only. Deprecated: This field is not populated.
    Output only. The names of the backups that reference this instance
    partition. Referencing backups should share the parent instance. The
    existence of any referencing backup prevents the instance partition from
    being deleted.
  referencingDatabases: Output only. The names of the databases that
    reference this instance partition. Referencing databases should share
    the parent instance. The existence of any referencing database prevents
    the instance partition from being deleted.
  state: Output only. The current instance partition state.
  updateTime: Output only. The time at which the instance partition was most
    recently updated.
c                   $    \ rS rSrSrSrSrSrSrg)&InstancePartition.StateValueValuesEnumi  a  Output only. The current instance partition state.

Values:
  STATE_UNSPECIFIED: Not specified.
  CREATING: The instance partition is still being created. Resources may
    not be available yet, and operations such as creating placements using
    this instance partition may not work.
  READY: The instance partition is fully created and ready to do work such
    as creating placements and using in databases.
r   r   r   r   Nr   r   r    r!   r   r    s    	 HEr    r   rU   r   r   r+   rY   rb   r   r   r`   r   r   Tr$   r   r   r   r   N)r   r   r   r   r   r   r   r   r(   rt  r   ru  r   rx  r   rB   rc   rd   re   r~  r  r   r   r   r   r   r   r   r    r!   ro  ro    s   7rY^^   ,,-@!D  #&$$Q'*%%a(+			q	!$			q	!$$$Q	0A0A0G0GH)**1i6G6G6M6MN/ ,,Q>"..rDA


4b
9%$$R(*r    ro  c                   <    \ rS rSrSr\R                  " S5      rSrg)rQ   i  zReplicaSelection identifies replicas with common properties.

Fields:
  location: Required. Name of the location of the replicas (for example,
    "us-central1").
r   r   N)	r   r   r   r   r   r   r   r  r   r   r    r!   rQ   rQ     s     ""1%(r    rQ   c                   <    \ rS rSrSr\R                  " SSSS9rSrg)	Keyi  zWA split key.

Fields:
  keyParts: Required. The column values making up the split key.
r  r   Tr$   r   N)	r   r   r   r   r   r   r(   keyPartsr   r   r    r!   r  r    s     ##$;QN(r    r  c                       \ rS rSrSr\R                  " SSSS9r\R                  " SSSS9r\R                  " SSSS9r	\R                  " SS	SS9r
S
rg)KeyRangei(  a  KeyRange represents a range of rows in a table or index. A range has a
start key and an end key. These keys can be open or closed, indicating if
the range includes rows with that key. Keys are represented by lists, where
the ith value in the list corresponds to the ith component of the table or
index primary key. Individual values are encoded as described here. For
example, consider the following table definition: CREATE TABLE UserEvents (
UserName STRING(MAX), EventDate STRING(10) ) PRIMARY KEY(UserName,
EventDate); The following keys name rows in this table: "Bob", "2014-09-23"
Since the `UserEvents` table's `PRIMARY KEY` clause names two columns, each
`UserEvents` key has two elements; the first is the `UserName`, and the
second is the `EventDate`. Key ranges with multiple components are
interpreted lexicographically by component using the table or index key's
declared sort order. For example, the following range returns all events for
user `"Bob"` that occurred in the year 2015: "start_closed": ["Bob",
"2015-01-01"] "end_closed": ["Bob", "2015-12-31"] Start and end keys can
omit trailing key components. This affects the inclusion and exclusion of
rows that exactly match the provided key components: if the key is closed,
then rows that exactly match the provided components are included; if the
key is open, then rows that exactly match are not included. For example, the
following range includes all events for `"Bob"` that occurred during and
after the year 2000: "start_closed": ["Bob", "2000-01-01"] "end_closed":
["Bob"] The next example retrieves all events for `"Bob"`: "start_closed":
["Bob"] "end_closed": ["Bob"] To retrieve events before the year 2000:
"start_closed": ["Bob"] "end_open": ["Bob", "2000-01-01"] The following
range includes all rows in the table: "start_closed": [] "end_closed": []
This range returns all users whose `UserName` begins with any character from
A to C: "start_closed": ["A"] "end_open": ["D"] This range returns all users
whose `UserName` begins with B: "start_closed": ["B"] "end_open": ["C"] Key
ranges honor column sort order. For example, suppose a table is defined as
follows: CREATE TABLE DescendingSortedTable { Key INT64, ... ) PRIMARY
KEY(Key DESC); The following range retrieves all rows with key values
between 1 and 100 inclusive: "start_closed": ["100"] "end_closed": ["1"]
Note that 100 is passed as the start, and 1 is passed as the end, because
`Key` is a descending column in the schema.

Fields:
  endClosed: If the end is closed, then the range includes all rows whose
    first `len(end_closed)` key columns exactly match `end_closed`.
  endOpen: If the end is open, then the range excludes rows whose first
    `len(end_open)` key columns exactly match `end_open`.
  startClosed: If the start is closed, then the range includes all rows
    whose first `len(start_closed)` key columns exactly match
    `start_closed`.
  startOpen: If the start is open, then the range excludes rows whose first
    `len(start_open)` key columns exactly match `start_open`.
r  r   Tr$   r   r+   rY   r   N)r   r   r   r   r   r   r(   	endClosedendOpenstartClosed	startOpenr   r   r    r!   r  r  (  s^    -^ $$%<a$O)""#:AM'&&'>DQ+$$%<a$O)r    r  c                      \ rS rSrSr\R                  " SSSS9r\R                  " S\R                  R                  S9r\R                  " S	S
5      r\R                  " S5      r\R                  " S	S5      r\R                  " S\R                  R                  S9r\R                   " S5      r\R                  " S	S5      r\R&                  " S\R                  R(                  S9rSrg)KeyRangeInfoi^  a  A message representing information for a key range (possibly one key).

Fields:
  contextValues: The list of context values for this key range.
  endKeyIndex: The index of the end key in indexed_keys.
  info: Information about this key range, for all metrics.
  keysCount: The number of keys this range covers.
  metric: The name of the metric. e.g. "latency".
  startKeyIndex: The index of the start key in indexed_keys.
  timeOffset: The time offset. This is the time since the start of the time
    interval.
  unit: The unit of the metric. This is an unstructured field and will be
    mapped as is to the user.
  value: The value of the metric.
r  r   Tr$   r   r`   r%  r+   rY   rb   r   r   r   r   r   N)r   r   r   r   r   r   r(   contextValuesrc   rd   re   endKeyIndexr  	keysCountr  startKeyIndexr   
timeOffsetr(  r)  r*  r   r   r   r    r!   r  r  ^  s      ((TJ-&&q)2C2C2I2IJ+			 11	5$$$Q')!!"3Q7&((I4E4E4K4KL-$$Q'*			 11	5$


q)*;*;*A*A
B%r    r  c                       \ rS rSrSr\R                  " SSSS9r\R                  " S\R                  R                  S9rS	rg
)rE  iz  aa  A message representing a list of specific information for multiple key
ranges.

Fields:
  infos: The list individual KeyRangeInfos.
  totalSize: The total size of the list of all KeyRangeInfos. This may be
    larger than the number of repeated messages above. If that is the case,
    this number may be used to determine how many are not being shown.
r  r   Tr$   r   r`   r   N)r   r   r   r   r   r   r(   infosrc   rd   re   	totalSizer   r   r    r!   rE  rE  z  s;     
 
 T
B%$$Q	0A0A0G0GH)r    rE  c                       \ rS rSrSr " S S\R                  5      r\R                  " S5      r	\R                  " SSSS9r\R                  " S	S
SS9rSrg)r  i  a  `KeySet` defines a collection of Cloud Spanner keys and/or key ranges.
All the keys are expected to be in the same table or index. The keys need
not be sorted in any particular way. If the same key is specified multiple
times in the set (for example if two ranges, two keys, or a key and a range
overlap), Cloud Spanner behaves as if the key were only specified once.

Messages:
  KeysValueListEntry: Single entry in a KeysValue.

Fields:
  all: For convenience `all` can be set to `true` to indicate that this
    `KeySet` matches all keys in the table or index. Note that any keys
    specified in `keys` or `ranges` are only yielded once.
  keys: A list of specific keys. Entries in `keys` should have exactly as
    many elements as there are columns in the primary or index key with
    which this `KeySet` is used. Individual key values are encoded as
    described here.
  ranges: A list of key ranges. See KeyRange for more information about key
    range specifications.
c                   <    \ rS rSrSr\R                  " SSSS9rSrg)	KeySet.KeysValueListEntryi  zRSingle entry in a KeysValue.

Fields:
  entry: A extra_types.JsonValue attribute.
r  r   Tr$   r   N	r   r   r   r   r   r   r(   entryr   r   r    r!   KeysValueListEntryr         ""#:AMEr    r  r   r   Tr$   r  r+   r   N)r   r   r   r   r   r   r'   r  r;   allr(   keysrangesr   r   r    r!   r  r    sV    *N9,, N 	q!#			 4a$	G$!!*a$?&r    r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
ListBackupOperationsResponsei  a  The response for ListBackupOperations.

Fields:
  nextPageToken: `next_page_token` can be sent in a subsequent
    ListBackupOperations call to fetch more of the matching metadata.
  operations: The list of matching backup long-running operations. Each
    operation's name will be prefixed by the backup's name. The operation's
    metadata field type `metadata.type_url` describes the type of the
    metadata. Operations returned include those that are pending or have
    completed/failed/canceled within the last 7 days. Operations returned
    are ordered by `operation.metadata.value.progress.start_time` in
    descending order starting from the most recently started operation.
r   	Operationr   Tr$   r   Nr   r   r   r   r   r   r   nextPageTokenr(   
operationsr   r   r    r!   r  r    s-     ''*-%%k1tD*r    r  c                   `    \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	Sr
g	)
ListBackupSchedulesResponsei  zThe response for ListBackupSchedules.

Fields:
  backupSchedules: The list of backup schedules for a database.
  nextPageToken: `next_page_token` can be sent in a subsequent
    ListBackupSchedules call to fetch more of the schedules.
r   r   Tr$   r   r   N)r   r   r   r   r   r   r(   r   r   r  r   r   r    r!   r  r    s.     **+;QN/''*-r    r  c                   `    \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	Sr
g	)
ListBackupsResponsei  aC  The response for ListBackups.

Fields:
  backups: The list of matching backups. Backups returned are ordered by
    `create_time` in descending order, starting from the most recent
    `create_time`.
  nextPageToken: `next_page_token` can be sent in a subsequent ListBackups
    call to fetch more of the matching backups.
rv   r   Tr$   r   r   N)r   r   r   r   r   r   r(   backupsr   r  r   r   r    r!   r  r    s-     ""8Q>'''*-r    r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
ListDatabaseOperationsResponsei  a  The response for ListDatabaseOperations.

Fields:
  nextPageToken: `next_page_token` can be sent in a subsequent
    ListDatabaseOperations call to fetch more of the matching metadata.
  operations: The list of matching database long-running operations. Each
    operation's name will be prefixed by the database's name. The
    operation's metadata field type `metadata.type_url` describes the type
    of the metadata.
r   r  r   Tr$   r   Nr  r   r    r!   r  r    s-    	 ''*-%%k1tD*r    r  c                   `    \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	Sr
g	)
ListDatabaseRolesResponsei  zThe response for ListDatabaseRoles.

Fields:
  databaseRoles: Database roles that matched the request.
  nextPageToken: `next_page_token` can be sent in a subsequent
    ListDatabaseRoles call to fetch more of the matching roles.
r  r   Tr$   r   r   N)r   r   r   r   r   r   r(   databaseRolesr   r  r   r   r    r!   r  r    s-     ((TJ-''*-r    r  c                   `    \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	Sr
g	)
ListDatabasesResponsei  zThe response for ListDatabases.

Fields:
  databases: Databases that matched the request.
  nextPageToken: `next_page_token` can be sent in a subsequent ListDatabases
    call to fetch more of the matching databases.
r  r   Tr$   r   r   N)r   r   r   r   r   r   r(   	databasesr   r  r   r   r    r!   r  r    s-     $$ZTB)''*-r    r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
$ListInstanceConfigOperationsResponsei  a  The response for ListInstanceConfigOperations.

Fields:
  nextPageToken: `next_page_token` can be sent in a subsequent
    ListInstanceConfigOperations call to fetch more of the matching
    metadata.
  operations: The list of matching instance configuration long-running
    operations. Each operation's name will be prefixed by the name of the
    instance configuration. The operation's metadata field type
    `metadata.type_url` describes the type of the metadata.
r   r  r   Tr$   r   Nr  r   r    r!   r  r    s-    
 ''*-%%k1tD*r    r  c                   `    \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	Sr
g	)
ListInstanceConfigsResponsei  a  The response for ListInstanceConfigs.

Fields:
  instanceConfigs: The list of requested instance configurations.
  nextPageToken: `next_page_token` can be sent in a subsequent
    ListInstanceConfigs call to fetch more of the matching instance
    configurations.
rU  r   Tr$   r   r   N)r   r   r   r   r   r   r(   instanceConfigsr   r  r   r   r    r!   r  r    s.     **+;QN/''*-r    r  c                       \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	\R                  " SSS9r
S	rg
)'ListInstancePartitionOperationsResponsei%  a  The response for ListInstancePartitionOperations.

Fields:
  nextPageToken: `next_page_token` can be sent in a subsequent
    ListInstancePartitionOperations call to fetch more of the matching
    metadata.
  operations: The list of matching instance partition long-running
    operations. Each operation's name will be prefixed by the instance
    partition's name. The operation's metadata field type
    `metadata.type_url` describes the type of the metadata.
  unreachableInstancePartitions: The list of unreachable instance
    partitions. It includes the names of instance partitions whose operation
    metadata could not be retrieved within instance_partition_deadline.
r   r  r   Tr$   r+   r   N)r   r   r   r   r   r   r   r  r(   r  unreachableInstancePartitionsr   r   r    r!   r  r  %  s@     ''*-%%k1tD*"+"7"7D"Ir    r  c                       \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	\R                  " SSS9r
S	rg
)ListInstancePartitionsResponsei:  a  The response for ListInstancePartitions.

Fields:
  instancePartitions: The list of requested instancePartitions.
  nextPageToken: `next_page_token` can be sent in a subsequent
    ListInstancePartitions call to fetch more of the matching instance
    partitions.
  unreachable: The list of unreachable instances or instance partitions. It
    includes the names of instances or instance partitions whose metadata
    could not be retrieved within instance_partition_deadline.
ro  r   Tr$   r   r+   r   N)r   r   r   r   r   r   r(   r   r   r  unreachabler   r   r    r!   r  r  :  sA    
 !--.A1tT''*-%%a$7+r    r  c                       \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	\R                  " SSS9r
S	rg
)ListInstancesResponseiL  as  The response for ListInstances.

Fields:
  instances: The list of requested instances.
  nextPageToken: `next_page_token` can be sent in a subsequent ListInstances
    call to fetch more of the matching instances.
  unreachable: The list of unreachable instances. It includes the names of
    instances whose metadata could not be retrieved within
    instance_deadline.
rh  r   Tr$   r   r+   r   N)r   r   r   r   r   r   r(   	instancesr   r  r  r   r   r    r!   r  r  L  s?    	 $$ZTB)''*-%%a$7+r    r  c                       \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	\R                  " SSS9r
S	rg
)ListOperationsResponsei]  a  The response message for Operations.ListOperations.

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

Fields:
  nextPageToken: Token to retrieve the next page of results, or empty if
    there are no more results in the list.
  scans: Available scans based on the list query parameters.
r   Scanr   Tr$   r   N)r   r   r   r   r   r   r   r  r(   scansr   r   r    r!   r  r  o  s-     ''*-

 
 T
:%r    r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
ListSessionsResponsei|  zThe response for ListSessions.

Fields:
  nextPageToken: `next_page_token` can be sent in a subsequent ListSessions
    call to fetch more of the matching sessions.
  sessions: The list of requested sessions.
r   r   r   Tr$   r   N)r   r   r   r   r   r   r   r  r(   sessionsr   r   r    r!   r  r  |  s-     ''*-##Iq4@(r    r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
ListSsdCachesResponsei  zThe response for ListSsdCaches.

Fields:
  nextPageToken: `next_page_token` can be sent in a subsequent ListSsdCaches
    call to fetch more of the matching SSD caches.
  ssdCaches: The list of requested SSD caches.
r   SsdCacher   Tr$   r   N)r   r   r   r   r   r   r   r  r(   	ssdCachesr   r   r    r!   r  r    s-     ''*-$$ZTB)r    r  c                       \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " SS5      r\R                  " S5      r\R                  " S5      rS	rg
)r%  i  a  A message representing a user-facing string whose value may need to be
translated before being displayed.

Messages:
  ArgsValue: A map of arguments used when creating the localized message.
    Keys represent parameter names which may be used by the localized
    version when substituting dynamic values.

Fields:
  args: A map of arguments used when creating the localized message. Keys
    represent parameter names which may be used by the localized version
    when substituting dynamic values.
  message: The canonical English version of this message. If no token is
    provided or the front-end has no message associated with the token, this
    text will be displayed as-is.
  token: The token identifying the message, e.g. 'METRIC_READ_CPU'. This
    should be unique within the service.
r   c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
LocalizedString.ArgsValuei  aB  A map of arguments used when creating the localized message. Keys
represent parameter names which may be used by the localized version when
substituting dynamic values.

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

Fields:
  additionalProperties: Additional properties of type ArgsValue
c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g),LocalizedString.ArgsValue.AdditionalPropertyi  z}An additional property for a ArgsValue object.

Fields:
  key: Name of the additional property.
  value: A string attribute.
r   r   r   Nr   r   r    r!   r"   r    r#   r    r"   r   Tr$   r   Nr&   r   r    r!   	ArgsValuer     s2    		'Y.. 	' %112FTXYr    r  r   r   r+   r   N)r   r   r   r   r   r   r,   r   r'   r  r(   argsr   messagetokenr   r   r    r!   r%  r%    sk    & !!"89Z)## Z :Z2 
		Q	/$!!!$'



"%r    r%  c                      \ rS rSrSr " S S\R                  5      r\R                  " S5       " S S\R                  5      5       r\R                  " S5       " S S	\R                  5      5       r\R                  " SS
5      r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R&                  " S5      r\R*                  " S\R,                  R.                  S9r\R                  " SS5      r\R                  " S	S5      r\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r\R&                  " S5      rSrg)Metrici  a  A message representing the actual monitoring data, values for each key
bucket over time, of a metric.

Enums:
  AggregationValueValuesEnum: The aggregation function used to aggregate
    each key bucket

Messages:
  IndexedHotKeysValue: The (sparse) mapping from time index to an
    IndexedHotKey message, representing those time intervals for which there
    are hot keys.
  IndexedKeyRangeInfosValue: The (sparse) mapping from time interval index
    to an IndexedKeyRangeInfos message, representing those time intervals
    for which there are informational messages concerning key ranges.

Fields:
  aggregation: The aggregation function used to aggregate each key bucket
  category: The category of the metric, e.g. "Activity", "Alerts", "Reads",
    etc.
  derived: The references to numerator and denominator metrics for a derived
    metric.
  displayLabel: The displayed label of the metric.
  hasNonzeroData: Whether the metric has any non-zero data.
  hotValue: The value that is considered hot for the metric. On a per metric
    basis hotness signals high utilization and something that might
    potentially be a cause for concern by the end user. hot_value is used to
    calibrate and scale visual color scales.
  indexedHotKeys: The (sparse) mapping from time index to an IndexedHotKey
    message, representing those time intervals for which there are hot keys.
  indexedKeyRangeInfos: The (sparse) mapping from time interval index to an
    IndexedKeyRangeInfos message, representing those time intervals for
    which there are informational messages concerning key ranges.
  info: Information about the metric.
  matrix: The data for the metric as a matrix.
  unit: The unit of the metric.
  visible: Whether the metric is visible to the end user.
c                   $    \ rS rSrSrSrSrSrSrg)!Metric.AggregationValueValuesEnumi  zThe aggregation function used to aggregate each key bucket

Values:
  AGGREGATION_UNSPECIFIED: Required default value.
  MAX: Use the maximum of all values.
  SUM: Use the sum of all values.
r   r   r   r   N)	r   r   r   r   r   AGGREGATION_UNSPECIFIEDMAXSUMr   r   r    r!   AggregationValueValuesEnumr
    s      
C
Cr    r  r   c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
Metric.IndexedHotKeysValuei  a3  The (sparse) mapping from time index to an IndexedHotKey message,
representing those time intervals for which there are hot keys.

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

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

Fields:
  key: Name of the additional property.
  value: A IndexedHotKey attribute.
r   r6  r   r   Nr  r   r    r!   r"   r  	  rF  r    r"   r   Tr$   r   Nr&   r   r    r!   IndexedHotKeysValuer    rH  r    r  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
 Metric.IndexedKeyRangeInfosValuei  aw  The (sparse) mapping from time interval index to an
IndexedKeyRangeInfos message, representing those time intervals for which
there are informational messages concerning key ranges.

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

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

Fields:
  key: Name of the additional property.
  value: A IndexedKeyRangeInfos attribute.
r   r@  r   r   Nr  r   r    r!   r"   r  %  s,    
 !!!$c$$%;Q?er    r"   r   Tr$   r   Nr&   r   r    r!   IndexedKeyRangeInfosValuer    s4    	@Y.. 	@ %112FTXYr    r  r   r%  r   r  r+   rY   rb   r   r`   r   r   r   MetricMatrixr   r   r   r   N) r   r   r   r   r   r   r   r  r   r,   r'   r  r  r   aggregationr(   categoryderiveddisplayLabelr;   hasNonzeroDatar)  rd   r*  hotValueindexedHotKeysindexedKeyRangeInfosr  matrixr(  visibler   r   r    r!   r  r    sb   $L
9>> 
 !!"89ZI-- Z :Z2 !!"89Z)"3"3 Z :Z6 ##$@!D+##$5q9(""?A6'''(91=,))!,.!!!Y->->-D-DE())*?C."//0KQO			 11	5$!!."5&			 12	6$""2&'r    r  c                   <    \ rS rSrSr\R                  " SSSS9rSrg)	r  i@  zTA message representing a matrix of floats.

Fields:
  rows: The rows of the matrix.
MetricMatrixRowr   Tr$   r   N)	r   r   r   r   r   r   r(   rowsr   r   r    r!   r  r  @  s     
		 11t	D$r    r  c                   d    \ rS rSrSr\R                  " SS\R                  R                  S9r	Sr
g)r%  iJ  z]A message representing a row of a matrix of floats.

Fields:
  cols: The columns of the row.
r   Tr   r   N)r   r   r   r   r   r   r)  rd   r*  colsr   r   r    r!   r%  r%  J  s)     
		a$	8I8I8O8O	P$r    r%  c                       \ rS rSrSr\R                  " SSSS9r\R                  " SSSS9r\R                  " SSSS9r	S	r
g
)r  iT  a  A mod describes all data changes in a watched table row.

Fields:
  keys: Returns the value of the primary key of the modified row.
  newValues: Returns the new values after the change for the modified
    columns. Always empty for DELETE.
  oldValues: Returns the old values before the change for the modified
    columns. Always empty for INSERT, or if old values are not being
    captured specified by value_capture_type.
ModValuer   Tr$   r   r+   r   N)r   r   r   r   r   r   r(   r  	newValues	oldValuesr   r   r    r!   r  r  T  sE    	 
		
A	=$$$ZTB)$$ZTB)r    r  c                       \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " SS5      rSrg)	r*  ie  a  Returns the value and associated metadata for a particular field of the
Mod.

Fields:
  columnMetadataIndex: Index within the repeated column_metadata field, to
    obtain the column metadata for the column that was modified.
  value: The value of the column.
r   r`   r  r   r   N)r   r   r   r   r   r   rc   rd   re   columnMetadataIndexr(   r   r   r   r    r!   r*  r*  e  s;     "..q):K:K:Q:QR

 
 !8!
<%r    r*  c                   <    \ rS rSrSr\R                  " S5      rSrg)MoveInEventis  a  Describes move-in of the key ranges into the change stream partition
identified by partition_token. To maintain processing the changes for a
particular key in timestamp order, the query processing the change stream
partition identified by partition_token should not advance beyond the
partition event record commit timestamp until the queries processing the
source change stream partitions have processed all change stream records
with timestamps <= the partition event record commit timestamp.

Fields:
  sourcePartitionToken: An unique partition identifier describing the source
    change stream partition that recorded changes for the key range that is
    moving into this partition.
r   r   N)	r   r   r   r   r   r   r   sourcePartitionTokenr   r   r    r!   r0  r0  s  s     #..q1r    r0  c                   `    \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	Sr
g	)
MoveInstanceRequesti  a-  The request for MoveInstance.

Fields:
  targetConfig: Required. The target instance configuration where to move
    the instance. Values are of the form `projects//instanceConfigs/`.
  targetDatabaseMoveConfigs: Optional. The configuration for each database
    in the target instance configuration.
r   r  r   Tr$   r   N)r   r   r   r   r   r   r   targetConfigr(   targetDatabaseMoveConfigsr   r   r    r!   r3  r3    s0     &&q),'445I1W[\r    r3  c                   <    \ rS rSrSr\R                  " S5      rSrg)MoveOutEventi  ai  Describes move-out of the key ranges out of the change stream partition
identified by partition_token. To maintain processing the changes for a
particular key in timestamp order, the query processing the MoveOutEvent in
the partition identified by partition_token should inform the queries
processing the destination partitions that they can unblock and proceed
processing records past the commit_timestamp.

Fields:
  destinationPartitionToken: An unique partition identifier describing the
    destination change stream partition that will record changes for the key
    range that is moving out of this partition.
r   r   N)	r   r   r   r   r   r   r   destinationPartitionTokenr   r   r    r!   r7  r7    s     (33A6r    r7  c                       \ rS rSrSr\R                  " S5      r\R                  " S\R                  R                  S9rSrg)r  i  a	  When a read-write transaction is executed on a multiplexed session, this
precommit token is sent back to the client as a part of the Transaction
message in the BeginTransaction response and also as a part of the ResultSet
and PartialResultSet responses.

Fields:
  precommitToken: Opaque precommit token.
  seqNum: An incrementing seq number is generated on every precommit token
    that is returned. Clients should remember the precommit token with the
    highest sequence number from the current transaction attempt.
r   r   r`   r   N)r   r   r   r   r   r   r.   r	  rc   rd   re   seqNumr   r   r    r!   r  r    s7    
 ''*.!!!Y->->-D-DE&r    r  c                       \ rS rSrSr\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r	\R                  " SS5      r
\R                  " SS	5      rS
rg)r   i  ar  A modification to one or more Cloud Spanner rows. Mutations can be
applied to a Cloud Spanner database by sending them in a Commit call.

Fields:
  delete: Delete rows from a table. Succeeds whether or not the named rows
    were present.
  insert: Insert new rows in a table. If any of the rows already exist, the
    write or transaction fails with error `ALREADY_EXISTS`.
  insertOrUpdate: Like insert, except that if the row already exists, then
    its column values are overwritten with the ones provided. Any column
    values not explicitly written are preserved. When using
    insert_or_update, just as when using insert, all `NOT NULL` columns in
    the table must be given a value. This holds true even when the row
    already exists and will therefore actually be updated.
  replace: Like insert, except that if the row already exists, it is
    deleted, and the column values provided are inserted instead. Unlike
    insert_or_update, this means any values not explicitly written become
    `NULL`. In an interleaved table, if you create the child table with the
    `ON DELETE CASCADE` annotation, then replacing a parent row also deletes
    the child rows. Otherwise, you must delete the child rows before you
    replace the parent row.
  update: Update existing rows in a table. If any of the rows does not
    already exist, the transaction fails with error `NOT_FOUND`.
r  r   Writer   r+   rY   rb   r   N)r   r   r   r   r   r   r(   deleteinsertinsertOrUpdatereplaceupdater   r   r    r!   r   r     sc    2 !!(A.&!!'1-&))'15.""7A.'!!'1-&r    r   c                   <    \ rS rSrSr\R                  " SSSS9rSrg)	r   i  a  A group of mutations to be committed together. Related mutations should
be placed in a group. For example, two mutations inserting rows with the
same primary key prefix in both parent and child tables are related.

Fields:
  mutations: Required. The mutations in this group.
r   r   Tr$   r   N)	r   r   r   r   r   r   r(   r  r   r   r    r!   r   r     s     $$ZTB)r    r   c                   z   \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " S5       " S S\R                  5      5       r
\R                  " S5      r\R                  " S	S
5      r\R                  " SS5      r\R                   " S5      r\R                  " SS5      rSrg)r  i  a  This resource represents a long-running operation that is the result of
a network API call.

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

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

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

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

Fields:
  key: Name of the additional property.
  value: A extra_types.JsonValue attribute.
r   r  r   r   Nr  r   r    r!   r"   rG    r  r    r"   r   Tr$   r   Nr&   r   r    r!   MetadataValuerE    4    	AY.. 	A %112FTXYr    rI  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
Operation.ResponseValuei(  a  The normal, successful response of the operation. If the original
method returns no data on success, such as `Delete`, the response is
`google.protobuf.Empty`. If the original method is standard
`Get`/`Create`/`Update`, the response should be the resource. For other
methods, the response should have the type `XxxResponse`, where `Xxx` is
the original method name. For example, if the original method name is
`TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`.

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

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

Fields:
  key: Name of the additional property.
  value: A extra_types.JsonValue attribute.
r   r  r   r   Nr  r   r    r!   r"   rN  :  r  r    r"   r   Tr$   r   Nr&   r   r    r!   ResponseValuerL  (  s4     	AY.. 	A %112FTXYr    rO  r   r   r   r+   rY   rb   r   N)r   r   r   r   r   r   r,   r   r'   rI  rO  r;   doner(   errormetadatar   rB   responser   r   r    r!   r  r    s    'R !!"89Zi'' Z :Z6 !!"89Zi'' Z :Z< 
			"$

 
 1
-%##OQ7(			q	!$##OQ7(r    r  c                       \ rS rSrSr\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " S5      rSrg)	r  iN  aM  Encapsulates progress related information for a Cloud Spanner long
running operation.

Fields:
  endTime: If set, the time at which this operation failed or was completed
    successfully.
  progressPercent: Percent completion of the operation. Values are between 0
    and 100 inclusive.
  startTime: Time the request was received.
r   r   r`   r+   r   Nr  r   r    r!   r  r  N  r  r    r  c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g) OptimizeRestoredDatabaseMetadatai_  a  Metadata type for the long-running operation used to track the progress
of optimizations performed on a newly restored database. This long-running
operation is automatically created by the system after the successful
completion of a database restore, and cannot be cancelled.

Fields:
  name: Name of the restored database being optimized.
  progress: The progress of the post-restore optimizations.
r   r  r   r   N)r   r   r   r   r   r   r   rB   r(   r  r   r   r    r!   rV  rV  _  s,     
		q	!$##$7;(r    rV  c                      \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " SS5      r
\R                  " SS5      r\R                  " S	5      r\R                  " S
S5      r\R                  " SSSS9rSrg)PartialResultSetin  a  Partial results from a streaming read or SQL query. Streaming reads and
SQL queries better tolerate large result sets, large rows, and large values,
but are a little trickier to consume.

Fields:
  chunkedValue: If true, then the final value in values is chunked, and must
    be combined with more values from subsequent `PartialResultSet`s to
    obtain a complete field value.
  last: Optional. Indicates whether this is the last `PartialResultSet` in
    the stream. The server might optionally set this field. Clients
    shouldn't rely on this field being set in all cases.
  metadata: Metadata about the result set, such as row type information.
    Only present in the first response.
  precommitToken: Optional. A precommit token is included if the read-write
    transaction has multiplexed sessions enabled. Pass the precommit token
    with the highest sequence number from this transaction attempt to the
    Commit request for this transaction.
  resumeToken: Streaming calls might be interrupted for a variety of
    reasons, such as TCP connection loss. If this occurs, the stream of
    results can be resumed by re-sending the original request and including
    `resume_token`. Note that executing any other transaction in the same
    session invalidates the token.
  stats: Query plan and execution statistics for the statement that produced
    this streaming result set. These can be requested by setting
    ExecuteSqlRequest.query_mode and are sent only once with the last
    response in the stream. This field is also present in the last response
    for DML statements.
  values: A streamed result set consists of a stream of values, which might
    be split into many `PartialResultSet` messages to accommodate large rows
    and/or large values. Every N complete values defines a row, where N is
    equal to the number of entries in metadata.row_type.fields. Most values
    are encoded based on type as described here. It's possible that the last
    value in values is "chunked", meaning that the rest of the value is sent
    in subsequent `PartialResultSet`(s). This is denoted by the
    chunked_value field. Two or more chunked values can be merged to form a
    complete value as follows: * `bool/number/null`: can't be chunked *
    `string`: concatenate the strings * `list`: concatenate the lists. If
    the last element in a list is a `string`, `list`, or `object`, merge it
    with the first element in the next list by applying these rules
    recursively. * `object`: concatenate the (field name, field value)
    pairs. If a field name is duplicated, then apply these rules recursively
    to merge the field values. Some examples of merging: Strings are
    concatenated. "foo", "bar" => "foobar" Lists of non-strings are
    concatenated. [2, 3], [4] => [2, 3, 4] Lists are concatenated, but the
    last and first elements are merged because they are strings. ["a", "b"],
    ["c", "d"] => ["a", "bc", "d"] Lists are concatenated, but the last and
    first elements are merged because they are lists. Recursively, the last
    and first elements of the inner lists are merged because they are
    strings. ["a", ["b", "c"]], [["d"], "e"] => ["a", ["b", "cd"], "e"] Non-
    overlapping object fields are combined. {"a": "1"}, {"b": "2"} => {"a":
    "1", "b": 2"} Overlapping object fields are merged. {"a": "1"}, {"a":
    "2"} => {"a": "12"} Examples of merging objects containing lists of
    strings. {"a": ["1"]}, {"a": ["2"]} => {"a": ["12"]} For a more complete
    example, suppose a streaming SQL query is yielding a result set whose
    rows contain a single string field. The following `PartialResultSet`s
    might be yielded: { "metadata": { ... } "values": ["Hello", "W"]
    "chunked_value": true "resume_token": "Af65..." } { "values": ["orl"]
    "chunked_value": true } { "values": ["d"] "resume_token": "Zx1B..." }
    This sequence of `PartialResultSet`s encodes two rows, one containing
    the field value `"Hello"`, and a second containing the field value
    `"World" = "W" + "orl" + "d"`. Not all `PartialResultSet`s contain a
    `resume_token`. Execution can only be resumed from a previously yielded
    `resume_token`. For the above sequence of `PartialResultSet`s, resuming
    the query with `"resume_token": "Af65..."` yields results from the
    `PartialResultSet` with value "orl".
r   r   ResultSetMetadatar+   r  rY   rb   ResultSetStatsr   r  r   Tr$   r   N)r   r   r   r   r   r   r;   chunkedValuer<   r(   rR  r	  r.   r  statsvaluesr   r   r    r!   rX  rX  n  s    AF ''*,				"$##$7;())*LaP.$$Q'+

 
 !11
5%!!"91tL&r    rX  c                   <    \ rS rSrSr\R                  " S5      rSrg)	Partitioni  a  Information returned for each partition returned in a PartitionResponse.

Fields:
  partitionToken: This token can be passed to `Read`, `StreamingRead`,
    `ExecuteSql`, or `ExecuteStreamingSql` requests to restrict the results
    to those identified by this partition token.
r   r   N)	r   r   r   r   r   r   r.   r  r   r   r    r!   r_  r_    s     ''*.r    r_  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S5      r	Sr
g)r   i  a  A partition end record serves as a notification that the client should
stop reading the partition. No further records are expected to be retrieved
on it.

Fields:
  endTimestamp: End timestamp at which the change stream partition is
    terminated. All changes generated by this partition will have timestamps
    <= end_timestamp. DataChangeRecord.commit_timestamps,
    PartitionStartRecord.start_timestamps,
    PartitionEventRecord.commit_timestamps, and
    PartitionEndRecord.end_timestamps can have the same value in the same
    partition. PartitionEndRecord is the last record returned for a
    partition.
  partitionToken: Unique partition identifier describing the terminated
    change stream partition. partition_token is equal to the partition token
    of the change stream partition currently queried to return this
    PartitionEndRecord.
  recordSequence: Record sequence numbers are unique and monotonically
    increasing (but not necessarily contiguous) for a specific timestamp
    across record types in the same partition. To guarantee ordered
    processing, the reader should process records (of potentially different
    types) in record_sequence order for a specific timestamp in the same
    partition.
r   r   r+   r   N)r   r   r   r   r   r   r   endTimestampr  r  r   r   r    r!   r   r     s9    2 &&q),((+.((+.r    r   c                       \ rS rSrSr\R                  " S5      r\R                  " SSSS9r	\R                  " SS	SS9r
\R                  " S
5      r\R                  " S5      rSrg)r   i  a  A partition event record describes key range changes for a change stream
partition. The changes to a row defined by its primary key can be captured
in one change stream partition for a specific time range, and then be
captured in a different change stream partition for a different time range.
This movement of key ranges across change stream partitions is a reflection
of activities, such as Spanner's dynamic splitting and load balancing, etc.
Processing this event is needed if users want to guarantee processing of the
changes for any key in timestamp order. If time ordered processing of
changes for a primary key is not needed, this event can be ignored. To
guarantee time ordered processing for each primary key, if the event
describes move-ins, the reader of this partition needs to wait until the
readers of the source partitions have processed all records with timestamps
<= this PartitionEventRecord.commit_timestamp, before advancing beyond this
PartitionEventRecord. If the event describes move-outs, the reader can
notify the readers of the destination partitions that they can continue
processing.

Fields:
  commitTimestamp: Indicates the commit timestamp at which the key range
    change occurred. DataChangeRecord.commit_timestamps,
    PartitionStartRecord.start_timestamps,
    PartitionEventRecord.commit_timestamps, and
    PartitionEndRecord.end_timestamps can have the same value in the same
    partition.
  moveInEvents: Set when one or more key ranges are moved into the change
    stream partition identified by partition_token. Example: Two key ranges
    are moved into partition (P1) from partition (P2) and partition (P3) in
    a single transaction at timestamp T. The PartitionEventRecord returned
    in P1 will reflect the move as: PartitionEventRecord { commit_timestamp:
    T partition_token: "P1" move_in_events { source_partition_token: "P2" }
    move_in_events { source_partition_token: "P3" } } The
    PartitionEventRecord returned in P2 will reflect the move as:
    PartitionEventRecord { commit_timestamp: T partition_token: "P2"
    move_out_events { destination_partition_token: "P1" } } The
    PartitionEventRecord returned in P3 will reflect the move as:
    PartitionEventRecord { commit_timestamp: T partition_token: "P3"
    move_out_events { destination_partition_token: "P1" } }
  moveOutEvents: Set when one or more key ranges are moved out of the change
    stream partition identified by partition_token. Example: Two key ranges
    are moved out of partition (P1) to partition (P2) and partition (P3) in
    a single transaction at timestamp T. The PartitionEventRecord returned
    in P1 will reflect the move as: PartitionEventRecord { commit_timestamp:
    T partition_token: "P1" move_out_events { destination_partition_token:
    "P2" } move_out_events { destination_partition_token: "P3" } } The
    PartitionEventRecord returned in P2 will reflect the move as:
    PartitionEventRecord { commit_timestamp: T partition_token: "P2"
    move_in_events { source_partition_token: "P1" } } The
    PartitionEventRecord returned in P3 will reflect the move as:
    PartitionEventRecord { commit_timestamp: T partition_token: "P3"
    move_in_events { source_partition_token: "P1" } }
  partitionToken: Unique partition identifier describing the partition this
    event occurred on. partition_token is equal to the partition token of
    the change stream partition currently queried to return this
    PartitionEventRecord.
  recordSequence: Record sequence numbers are unique and monotonically
    increasing (but not necessarily contiguous) for a specific timestamp
    across record types in the same partition. To guarantee ordered
    processing, the reader should process records (of potentially different
    types) in record_sequence order for a specific timestamp in the same
    partition.
r   r0  r   Tr$   r7  r+   rY   rb   r   N)r   r   r   r   r   r   r   r   r(   moveInEventsmoveOutEventsr  r  r   r   r    r!   r   r     sb    <| ))!,/''q4H,((TJ-((+.((+.r    r   c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)PartitionOptionsi,  ad  Options for a `PartitionQueryRequest` and `PartitionReadRequest`.

Fields:
  maxPartitions: **Note:** This hint is currently ignored by
    `PartitionQuery` and `PartitionRead` requests. The desired maximum
    number of partitions to return. For example, this might be set to the
    number of workers available. The default for this option is currently
    10,000. The maximum value is currently 200,000. This is only a hint. The
    actual number of partitions returned can be smaller or larger than this
    maximum count request.
  partitionSizeBytes: **Note:** This hint is currently ignored by
    `PartitionQuery` and `PartitionRead` requests. The desired data size for
    each partition generated. The default for this option is currently 1
    GiB. This is only a hint. The actual size of each partition can be
    smaller or larger than this size request.
r   r   r   N)
r   r   r   r   r   r   rc   maxPartitionspartitionSizeBytesr   r   r    r!   rf  rf  ,  s*    " ((+- --a0r    rf  c                   |   \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " S5       " S S\R                  5      5       r
\R                  " SS5      r\R                  " SS	5      r\R                  " S
S5      r\R                  " S5      r\R                  " SS5      rSrg)PartitionQueryRequestiB  a  The request for PartitionQuery

Messages:
  ParamTypesValue: It isn't always possible for Cloud Spanner to infer the
    right SQL type from a JSON value. For example, values of type `BYTES`
    and values of type `STRING` both appear in params as JSON strings. In
    these cases, `param_types` can be used to specify the exact SQL type for
    some or all of the SQL query parameters. See the definition of Type for
    more information about SQL types.
  ParamsValue: Parameter names and values that bind to placeholders in the
    SQL string. A parameter placeholder consists of the `@` character
    followed by the parameter name (for example, `@firstName`). Parameter
    names can contain letters, numbers, and underscores. Parameters can
    appear anywhere that a literal value is expected. The same parameter
    name can be used more than once, for example: `"WHERE id > @msg_id AND
    id < @msg_id + 100"` It's an error to execute a SQL statement with
    unbound parameters.

Fields:
  paramTypes: It isn't always possible for Cloud Spanner to infer the right
    SQL type from a JSON value. For example, values of type `BYTES` and
    values of type `STRING` both appear in params as JSON strings. In these
    cases, `param_types` can be used to specify the exact SQL type for some
    or all of the SQL query parameters. See the definition of Type for more
    information about SQL types.
  params: Parameter names and values that bind to placeholders in the SQL
    string. A parameter placeholder consists of the `@` character followed
    by the parameter name (for example, `@firstName`). Parameter names can
    contain letters, numbers, and underscores. Parameters can appear
    anywhere that a literal value is expected. The same parameter name can
    be used more than once, for example: `"WHERE id > @msg_id AND id <
    @msg_id + 100"` It's an error to execute a SQL statement with unbound
    parameters.
  partitionOptions: Additional options that affect how many partitions are
    created.
  sql: Required. The query request to generate partitions for. The request
    fails if the query isn't root partitionable. For a query to be root
    partitionable, it needs to satisfy a few conditions. For example, if the
    query execution plan contains a distributed union operator, then it must
    be the first operator in the plan. For more information about other
    conditions, see [Read data in parallel](https://cloud.google.com/spanner
    /docs/reads#read_data_in_parallel). The query request must not contain
    DML commands, such as `INSERT`, `UPDATE`, or `DELETE`. Use
    `ExecuteStreamingSql` with a `PartitionedDml` transaction for large,
    partition-friendly DML operations.
  transaction: Read-only snapshot transactions are supported, read and write
    and single-use transactions are not.
r   c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
%PartitionQueryRequest.ParamTypesValueit  a  It isn't always possible for Cloud Spanner to infer the right SQL type
from a JSON value. For example, values of type `BYTES` and values of type
`STRING` both appear in params as JSON strings. In these cases,
`param_types` can be used to specify the exact SQL type for some or all of
the SQL query parameters. See the definition of Type for more information
about SQL types.

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

Fields:
  additionalProperties: Additional properties of type ParamTypesValue
c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)8PartitionQueryRequest.ParamTypesValue.AdditionalPropertyi  r  r   r  r   r   Nr  r   r    r!   r"   rn    r  r    r"   r   Tr$   r   Nr&   r   r    r!   r  rl  t  r  r    r  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
!PartitionQueryRequest.ParamsValuei  ax  Parameter names and values that bind to placeholders in the SQL
string. A parameter placeholder consists of the `@` character followed by
the parameter name (for example, `@firstName`). Parameter names can
contain letters, numbers, and underscores. Parameters can appear anywhere
that a literal value is expected. The same parameter name can be used more
than once, for example: `"WHERE id > @msg_id AND id < @msg_id + 100"` It's
an error to execute a SQL statement with unbound parameters.

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

Fields:
  additionalProperties: Properties of the object.
c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)4PartitionQueryRequest.ParamsValue.AdditionalPropertyi  r  r   r  r   r   Nr  r   r    r!   r"   rr    r  r    r"   r   Tr$   r   Nr&   r   r    r!   r  rp    4    	AY.. 	A %112FTXYr    r  r   r   rf  r+   rY   r  rb   r   N)r   r   r   r   r   r   r,   r   r'   r  r  r(   r  r  partitionOptionsr   r  r  r   r   r    r!   rj  rj  B  s    /b !!"89Z	)) Z :Z8 !!"89ZI%% Z :Z: %%&7;*!!-3&++,>Ba #&&'<a@+r    rj  c                       \ rS rSrSr\R                  " SSS9r\R                  " S5      r\R                  " SS5      r
\R                  " S	S
5      r\R                  " S5      r\R                  " SS5      rSrg)PartitionReadRequesti  a  The request for PartitionRead

Fields:
  columns: The columns of table to be returned for each row matching this
    request.
  index: If non-empty, the name of an index on table. This index is used
    instead of the table primary key when interpreting key_set and sorting
    result rows. See key_set for further information.
  keySet: Required. `key_set` identifies the rows to be yielded. `key_set`
    names the primary keys of the rows in table to be yielded, unless index
    is present. If index is present, then key_set instead names index keys
    in index. It isn't an error for the `key_set` to name rows that don't
    exist in the database. Read yields nothing for nonexistent rows.
  partitionOptions: Additional options that affect how many partitions are
    created.
  table: Required. The name of the table in the database to be read.
  transaction: Read only snapshot transactions are supported, read/write and
    single use transactions are not.
r   Tr$   r   r  r+   rf  rY   rb   r  r   r   N)r   r   r   r   r   r   r   columnsindexr(   r  rt  r  r  r   r   r    r!   rv  rv    st    ( !!!d3'



"%!!(A.&++,>B



"%&&'<a@+r    rv  c                   b    \ rS rSrSr\R                  " SSSS9r\R                  " SS5      rS	r	g
)PartitionResponsei  zThe response for PartitionQuery or PartitionRead

Fields:
  partitions: Partitions created by this request.
  transaction: Transaction created by this request.
r_  r   Tr$   Transactionr   r   N)
r   r   r   r   r   r   r(   
partitionsr  r   r   r    r!   rz  rz    s/     %%k1tD*&&}a8+r    rz  c                       \ rS rSrSr\R                  " SSS9r\R                  " S5      r\R                  " S5      r	Sr
g	)
r   i  a  A partition start record serves as a notification that the client should
schedule the partitions to be queried. PartitionStartRecord returns
information about one or more partitions.

Fields:
  partitionTokens: Unique partition identifiers to be used in queries.
  recordSequence: Record sequence numbers are unique and monotonically
    increasing (but not necessarily contiguous) for a specific timestamp
    across record types in the same partition. To guarantee ordered
    processing, the reader should process records (of potentially different
    types) in record_sequence order for a specific timestamp in the same
    partition.
  startTimestamp: Start timestamp at which the partitions should be queried
    to return change stream records with timestamps >= start_timestamp.
    DataChangeRecord.commit_timestamps,
    PartitionStartRecord.start_timestamps,
    PartitionEventRecord.commit_timestamps, and
    PartitionEndRecord.end_timestamps can have the same value in the same
    partition.
r   Tr$   r   r+   r   N)r   r   r   r   r   r   r   partitionTokensr  startTimestampr   r   r    r!   r   r     s;    * ))!d;/((+.((+.r    r   c                       \ rS rSrSrSrg)PartitionedDmli  z7Message type to initiate a Partitioned DML transaction.r   NrL   r   r    r!   r  r    s    @r    r  c                      \ rS rSrSr " S S\R                  5      r\R                  " S5       " S S\R                  5      5       r\R                  " S5       " S S	\R                  5      5       r\R                  " S
SSS9r\R                  " S5      r\R                  " SS5      r\R$                  " S\R&                  R(                  S9r\R,                  " SS5      r\R                  " S	S5      r\R                  " SS5      rSrg)PlanNodei  a  Node information for nodes appearing in a QueryPlan.plan_nodes.

Enums:
  KindValueValuesEnum: Used to determine the type of node. May be needed for
    visualizing different kinds of nodes differently. For example, If the
    node is a SCALAR node, it will have a condensed representation which can
    be used to directly embed a description of the node in its parent.

Messages:
  ExecutionStatsValue: The execution statistics associated with the node,
    contained in a group of key-value pairs. Only present if the plan was
    returned as a result of a profile query. For example, number of
    executions, number of rows/time per execution etc.
  MetadataValue: Attributes relevant to the node contained in a group of
    key-value pairs. For example, a Parameter Reference node could have the
    following information in its metadata: { "parameter_reference":
    "param1", "parameter_type": "array" }

Fields:
  childLinks: List of child node `index`es and their relationship to this
    parent.
  displayName: The display name for the node.
  executionStats: The execution statistics associated with the node,
    contained in a group of key-value pairs. Only present if the plan was
    returned as a result of a profile query. For example, number of
    executions, number of rows/time per execution etc.
  index: The `PlanNode`'s index in node list.
  kind: Used to determine the type of node. May be needed for visualizing
    different kinds of nodes differently. For example, If the node is a
    SCALAR node, it will have a condensed representation which can be used
    to directly embed a description of the node in its parent.
  metadata: Attributes relevant to the node contained in a group of key-
    value pairs. For example, a Parameter Reference node could have the
    following information in its metadata: { "parameter_reference":
    "param1", "parameter_type": "array" }
  shortRepresentation: Condensed representation for SCALAR nodes.
c                   $    \ rS rSrSrSrSrSrSrg)PlanNode.KindValueValuesEnumi%  a  Used to determine the type of node. May be needed for visualizing
different kinds of nodes differently. For example, If the node is a SCALAR
node, it will have a condensed representation which can be used to
directly embed a description of the node in its parent.

Values:
  KIND_UNSPECIFIED: Not specified.
  RELATIONAL: Denotes a Relational operator node in the expression tree.
    Relational operators represent iterative processing of rows during
    query execution. For example, a `TableScan` operation that reads rows
    from a table.
  SCALAR: Denotes a Scalar node in the expression tree. Scalar nodes
    represent non-iterable entities in the query plan. For example,
    constants or arithmetic operators appearing inside predicate
    expressions or references to column names.
r   r   r   r   N)	r   r   r   r   r   KIND_UNSPECIFIED
RELATIONALSCALARr   r   r    r!   KindValueValuesEnumr  %  s      JFr    r  r   c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
PlanNode.ExecutionStatsValuei:  a  The execution statistics associated with the node, contained in a
group of key-value pairs. Only present if the plan was returned as a
result of a profile query. For example, number of executions, number of
rows/time per execution etc.

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

Fields:
  additionalProperties: Properties of the object.
c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)/PlanNode.ExecutionStatsValue.AdditionalPropertyiI  zAn additional property for a ExecutionStatsValue object.

Fields:
  key: Name of the additional property.
  value: A extra_types.JsonValue attribute.
r   r  r   r   Nr  r   r    r!   r"   r  I  r  r    r"   r   Tr$   r   Nr&   r   r    r!   ExecutionStatsValuer  :  rJ  r    r  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
PlanNode.MetadataValueiV  au  Attributes relevant to the node contained in a group of key-value
pairs. For example, a Parameter Reference node could have the following
information in its metadata: { "parameter_reference": "param1",
"parameter_type": "array" }

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

Fields:
  additionalProperties: Properties of the object.
c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g))PlanNode.MetadataValue.AdditionalPropertyid  rH  r   r  r   r   Nr  r   r    r!   r"   r  d  r  r    r"   r   Tr$   r   Nr&   r   r    r!   rI  r  V  4    
	AY.. 	A %112FTXYr    rI  r   r   Tr$   r   r+   rY   r`   rb   r   ShortRepresentationr   r   N)r   r   r   r   r   r   r   r  r   r,   r'   r  rI  r(   
childLinksr   rx  executionStatsrc   rd   re   rx  r   kindrR  shortRepresentationr   r   r    r!   r  r    s   $LINN * !!"89ZI-- Z :Z6 !!"89Zi'' Z :Z4 %%k1tD*%%a(+))*?C.

 
 I,=,=,C,C
D%			2A	6$##OQ7(!../DaHr    r  c                       \ rS rSrSr\R                  " SSSS9r\R                  " S5      r	\R                  " S\R                  R                  S	9rS
rg)Policyiz  a*  An Identity and Access Management (IAM) policy, which specifies access
controls for Google Cloud resources. A `Policy` is a collection of
`bindings`. A `binding` binds one or more `members`, or principals, to a
single `role`. Principals can be user accounts, service accounts, Google
groups, and domains (such as G Suite). A `role` is a named list of
permissions; each `role` can be an IAM predefined role or a user-created
custom role. For some types of Google Cloud resources, a `binding` can also
specify a `condition`, which is a logical expression that allows access to a
resource only if the expression evaluates to `true`. A condition can add
constraints based on attributes of the request, the resource, or both. To
learn which resources support conditions in their IAM policies, see the [IAM
documentation](https://cloud.google.com/iam/help/conditions/resource-
policies). **JSON example:** ``` { "bindings": [ { "role":
"roles/resourcemanager.organizationAdmin", "members": [
"user:mike@example.com", "group:admins@example.com", "domain:google.com",
"serviceAccount:my-project-id@appspot.gserviceaccount.com" ] }, { "role":
"roles/resourcemanager.organizationViewer", "members": [
"user:eve@example.com" ], "condition": { "title": "expirable access",
"description": "Does not grant access after Sep 2020", "expression":
"request.time < timestamp('2020-10-01T00:00:00.000Z')", } } ], "etag":
"BwWWja0YfJA=", "version": 3 } ``` **YAML example:** ``` bindings: -
members: - user:mike@example.com - group:admins@example.com -
domain:google.com - serviceAccount:my-project-id@appspot.gserviceaccount.com
role: roles/resourcemanager.organizationAdmin - members: -
user:eve@example.com role: roles/resourcemanager.organizationViewer
condition: title: expirable access description: Does not grant access after
Sep 2020 expression: request.time < timestamp('2020-10-01T00:00:00.000Z')
etag: BwWWja0YfJA= version: 3 ``` For a description of IAM and its features,
see the [IAM documentation](https://cloud.google.com/iam/docs/).

Fields:
  bindings: Associates a list of `members`, or principals, with a `role`.
    Optionally, may specify a `condition` that determines how and when the
    `bindings` are applied. Each of the `bindings` must contain at least one
    principal. The `bindings` in a `Policy` can refer to up to 1,500
    principals; up to 250 of these principals can be Google groups. Each
    occurrence of a principal counts towards these limits. For example, if
    the `bindings` grant 50 different roles to `user:alice@example.com`, and
    not to any other principal, then you can add another 1,450 principals to
    the `bindings` in the `Policy`.
  etag: `etag` is used for optimistic concurrency control as a way to help
    prevent simultaneous updates of a policy from overwriting each other. It
    is strongly suggested that systems make use of the `etag` in the read-
    modify-write cycle to perform policy updates in order to avoid race
    conditions: An `etag` is returned in the response to `getIamPolicy`, and
    systems are expected to put that etag in the request to `setIamPolicy`
    to ensure that their change will be applied to the same version of the
    policy. **Important:** If you use IAM Conditions, you must include the
    `etag` field whenever you call `setIamPolicy`. If you omit this field,
    then IAM allows you to overwrite a version `3` policy with a version `1`
    policy, and all of the conditions in the version `3` policy are lost.
  version: Specifies the format of the policy. Valid values are `0`, `1`,
    and `3`. Requests that specify an invalid value are rejected. Any
    operation that affects conditional role bindings must specify version
    `3`. This requirement applies to the following operations: * Getting a
    policy that includes a conditional role binding * Adding a conditional
    role binding to a policy * Changing a conditional role binding in a
    policy * Removing any role binding, with or without a condition, from a
    policy that includes conditions **Important:** If you use IAM
    Conditions, you must include the `etag` field whenever you call
    `setIamPolicy`. If you omit this field, then IAM allows you to overwrite
    a version `3` policy with a version `1` policy, and all of the
    conditions in the version `3` policy are lost. If a policy does not
    include any conditions, operations on that policy may specify any valid
    version or leave the field unset. To learn which resources support
    conditions in their IAM policies, see the [IAM
    documentation](https://cloud.google.com/iam/help/conditions/resource-
    policies).
r   r   Tr$   r   r+   r`   r   N)r   r   r   r   r   r   r(   bindingsr.   r   rc   rd   re   versionr   r   r    r!   r  r  z  sM    DL ##Iq4@(			a	 $""1i.?.?.E.EF'r    r  c                   >   \ rS rSrSr\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " S\R                  R                  S9r\R                  " S\R                  R                  S9r\R                  " S5      rS	rg
)
PrefixNodei  a  A message representing a key prefix node in the key prefix hierarchy.
for eg. Bigtable keyspaces are lexicographically ordered mappings of keys to
values. Keys often have a shared prefix structure where users use the keys
to organize data. Eg ///employee In this case Keysight will possibly use one
node for a company and reuse it for all employees that fall under the
company. Doing so improves legibility in the UI.

Fields:
  dataSourceNode: Whether this corresponds to a data_source name.
  depth: The depth in the prefix hierarchy.
  endIndex: The index of the end key bucket of the range that this node
    spans.
  startIndex: The index of the start key bucket of the range that this node
    spans.
  word: The string represented by the prefix node.
r   r   r`   r+   rY   rb   r   N)r   r   r   r   r   r   r;   dataSourceNoderc   rd   re   depthendIndex
startIndexr   wordr   r   r    r!   r  r    s    " ))!,.

 
 I,=,=,C,C
D%##Ay/@/@/F/FG(%%a1B1B1H1HI*			q	!$r    r  c                   <    \ rS rSrSr\R                  " SSSS9rSrg)	QueryAdvisorResulti  a  Output of query advisor analysis.

Fields:
  indexAdvice: Optional. Index Recommendation for a query. This is an
    optional field and the recommendation will only be available when the
    recommendation guarantees significant improvement in query performance.
r2  r   Tr$   r   N)	r   r   r   r   r   r   r(   indexAdvicer   r   r    r!   r  r    s     &&}a$G+r    r  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)r  i  a  Query optimizer configuration.

Fields:
  optimizerStatisticsPackage: An option to control the selection of
    optimizer statistics package. This parameter allows individual queries
    to use a different query optimizer statistics package. Specifying
    `latest` as a value instructs Cloud Spanner to use the latest generated
    statistics package. If not specified, Cloud Spanner uses the statistics
    package set at the database level options, or the latest package if the
    database option isn't set. The statistics package requested by the query
    has to be exempt from garbage collection. This can be achieved with the
    following DDL statement: ```sql ALTER STATISTICS SET OPTIONS
    (allow_gc=false) ``` The list of available statistics packages can be
    queried from `INFORMATION_SCHEMA.SPANNER_STATISTICS`. Executing a SQL
    statement with an invalid optimizer statistics package or with a
    statistics package that allows garbage collection fails with an
    `INVALID_ARGUMENT` error.
  optimizerVersion: An option to control the selection of optimizer version.
    This parameter allows individual queries to pick different query
    optimizer versions. Specifying `latest` as a value instructs Cloud
    Spanner to use the latest supported query optimizer version. If not
    specified, Cloud Spanner uses the optimizer version set at the database
    level options. Any other positive integer (from the list of supported
    optimizer versions) overrides the default optimizer version for query
    execution. The list of supported optimizer versions can be queried from
    `SPANNER_SYS.SUPPORTED_OPTIMIZER_VERSIONS`. Executing a SQL statement
    with an invalid optimizer version fails with an `INVALID_ARGUMENT`
    error. See https://cloud.google.com/spanner/docs/query-optimizer/manage-
    query-optimizer for more information on managing the query optimizer.
    The `optimizer_version` statement hint has precedence over this setting.
r   r   r   N)
r   r   r   r   r   r   r   optimizerStatisticsPackageoptimizerVersionr   r   r    r!   r  r    s,    @  )44Q7**1-r    r  c                   b    \ rS rSrSr\R                  " SSSS9r\R                  " SS5      rS	r	g
)	QueryPlani  a  Contains an ordered list of nodes appearing in the query plan.

Fields:
  planNodes: The nodes in the query plan. Plan nodes are returned in pre-
    order starting with the plan root. Each PlanNode's `id` corresponds to
    its index in `plan_nodes`.
  queryAdvice: Optional. The advise/recommendations for a query. Currently
    this field will be serving index recommendations for a query.
r  r   Tr$   r  r   r   N)
r   r   r   r   r   r   r(   	planNodesqueryAdvicer   r   r    r!   r  r    s0     $$ZTB)&&';Q?+r    r  c                       \ rS rSrSr " S S\R                  5      r\R                  " S5      r	\R                  " SS5      r\R                  " SS5      r\R                  " S	5      rS
rg)r  i  aq  Information about the dual-region quorum.

Enums:
  InitiatorValueValuesEnum: Output only. Whether this `ChangeQuorum` is
    Google or User initiated.

Fields:
  etag: Output only. The etag is used for optimistic concurrency control as
    a way to help prevent simultaneous `ChangeQuorum` requests that might
    create a race condition.
  initiator: Output only. Whether this `ChangeQuorum` is Google or User
    initiated.
  quorumType: Output only. The type of this quorum. See QuorumType for more
    information about quorum type specifications.
  startTime: Output only. The timestamp when the request was triggered.
c                   $    \ rS rSrSrSrSrSrSrg)#QuorumInfo.InitiatorValueValuesEnumi1  zOutput only. Whether this `ChangeQuorum` is Google or User initiated.

Values:
  INITIATOR_UNSPECIFIED: Unspecified.
  GOOGLE: `ChangeQuorum` initiated by Google.
  USER: `ChangeQuorum` initiated by User.
r   r   r   r   N)	r   r   r   r   r   INITIATOR_UNSPECIFIEDGOOGLEUSERr   r   r    r!   InitiatorValueValuesEnumr  1  s     FDr    r  r   r   r   r+   rY   r   N)r   r   r   r   r   r   r   r  r   r   r   rG   r(   r   r   r   r   r    r!   r  r    s^    "
 
 
		q	!$!!"<a@)%%lA6*##A&)r    r  c                   d    \ rS rSrSr\R                  " SS5      r\R                  " SS5      rSr	g)	r   iC  zInformation about the database quorum type. This only applies to dual-
region instance configs.

Fields:
  dualRegion: Dual-region quorum type.
  singleRegion: Single-region quorum type.
r  r   SingleRegionQuorumr   r   N)
r   r   r   r   r   r   r(   
dualRegionsingleRegionr   r   r    r!   r   r   C  s/     %%&8!<*''(<a@,r    r   c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S5      r	\R                  " S5      r
\R                  " S5      r\R                  " S5      rS	rg
)ReadOnlyiP  a	  Message type to initiate a read-only transaction.

Fields:
  exactStaleness: Executes all reads at a timestamp that is
    `exact_staleness` old. The timestamp is chosen soon after the read is
    started. Guarantees that all writes that have committed more than the
    specified number of seconds ago are visible. Because Cloud Spanner
    chooses the exact timestamp, this mode works even if the client's local
    clock is substantially skewed from Cloud Spanner commit timestamps.
    Useful for reading at nearby replicas without the distributed timestamp
    negotiation overhead of `max_staleness`.
  maxStaleness: Read data at a timestamp >= `NOW - max_staleness` seconds.
    Guarantees that all writes that have committed more than the specified
    number of seconds ago are visible. Because Cloud Spanner chooses the
    exact timestamp, this mode works even if the client's local clock is
    substantially skewed from Cloud Spanner commit timestamps. Useful for
    reading the freshest data available at a nearby replica, while bounding
    the possible staleness if the local replica has fallen behind. Note that
    this option can only be used in single-use transactions.
  minReadTimestamp: Executes all reads at a timestamp >=
    `min_read_timestamp`. This is useful for requesting fresher data than
    some previous read, or data that is fresh enough to observe the effects
    of some previously committed transaction whose timestamp is known. Note
    that this option can only be used in single-use transactions. A
    timestamp in RFC3339 UTC \"Zulu\" format, accurate to nanoseconds.
    Example: `"2014-10-02T15:01:23.045123456Z"`.
  readTimestamp: Executes all reads at the given timestamp. Unlike other
    modes, reads at a specific timestamp are repeatable; the same read at
    the same timestamp always returns the same data. If the timestamp is in
    the future, the read is blocked until the specified timestamp, modulo
    the read's deadline. Useful for large scale consistent reads such as
    mapreduces, or for coordinating many reads against a consistent snapshot
    of the data. A timestamp in RFC3339 UTC \"Zulu\" format, accurate to
    nanoseconds. Example: `"2014-10-02T15:01:23.045123456Z"`.
  returnReadTimestamp: If true, the Cloud Spanner-selected read timestamp is
    included in the Transaction message that describes the transaction.
  strong: Read at a timestamp where all previously committed transactions
    are visible.
r   r   r+   rY   rb   r   r   N)r   r   r   r   r   r   r   exactStalenessmaxStalenessminReadTimestampreadTimestampr;   returnReadTimestampstrongr   r   r    r!   r  r  P  sl    &P ((+.&&q),**1-''*-!..q1!!!$&r    r  c                   J   \ rS rSrSr " S S\R                  5      r " S S\R                  5      r\R                  " SSS	9r
\R                  " S
5      r\R                  " SS5      r\R                  " S5      r\R                  " SS5      r\R"                  " S5      r\R&                  " SS5      r\R&                  " SS5      r\R,                  " S5      r\R                  " SS5      r\R,                  " S5      r\R                  " S5      r\R                  " SS5      rSrg)ReadRequesti  a  The request for Read and StreamingRead.

Enums:
  LockHintValueValuesEnum: Optional. Lock Hint for the request, it can only
    be used with read-write transactions.
  OrderByValueValuesEnum: Optional. Order for the returned rows. By default,
    Spanner returns result rows in primary key order except for
    PartitionRead requests. For applications that don't require rows to be
    returned in primary key (`ORDER_BY_PRIMARY_KEY`) order, setting
    `ORDER_BY_NO_ORDER` option allows Spanner to optimize row retrieval,
    resulting in lower latencies in certain cases (for example, bulk point
    lookups).

Fields:
  columns: Required. The columns of table to be returned for each row
    matching this request.
  dataBoostEnabled: If this is for a partitioned read and this field is set
    to `true`, the request is executed with Spanner Data Boost independent
    compute resources. If the field is set to `true` but the request doesn't
    set `partition_token`, the API returns an `INVALID_ARGUMENT` error.
  directedReadOptions: Directed read options for this request.
  index: If non-empty, the name of an index on table. This index is used
    instead of the table primary key when interpreting key_set and sorting
    result rows. See key_set for further information.
  keySet: Required. `key_set` identifies the rows to be yielded. `key_set`
    names the primary keys of the rows in table to be yielded, unless index
    is present. If index is present, then key_set instead names index keys
    in index. If the partition_token field is empty, rows are yielded in
    table primary key order (if index is empty) or index key order (if index
    is non-empty). If the partition_token field isn't empty, rows are
    yielded in an unspecified order. It isn't an error for the `key_set` to
    name rows that don't exist in the database. Read yields nothing for
    nonexistent rows.
  limit: If greater than zero, only the first `limit` rows are yielded. If
    `limit` is zero, the default is no limit. A limit can't be specified if
    `partition_token` is set.
  lockHint: Optional. Lock Hint for the request, it can only be used with
    read-write transactions.
  orderBy: Optional. Order for the returned rows. By default, Spanner
    returns result rows in primary key order except for PartitionRead
    requests. For applications that don't require rows to be returned in
    primary key (`ORDER_BY_PRIMARY_KEY`) order, setting `ORDER_BY_NO_ORDER`
    option allows Spanner to optimize row retrieval, resulting in lower
    latencies in certain cases (for example, bulk point lookups).
  partitionToken: If present, results are restricted to the specified
    partition previously created using `PartitionRead`. There must be an
    exact match for the values of fields common to this message and the
    PartitionReadRequest message used to create this partition_token.
  requestOptions: Common options for this request.
  resumeToken: If this request is resuming a previously interrupted read,
    `resume_token` should be copied from the last PartialResultSet yielded
    before the interruption. Doing this enables the new read to resume where
    the last read left off. The rest of the request parameters must exactly
    match the request that yielded this token.
  table: Required. The name of the table in the database to be read.
  transaction: The transaction to use. If none is provided, the default is a
    temporary read-only transaction with strong concurrency.
c                   $    \ rS rSrSrSrSrSrSrg)#ReadRequest.LockHintValueValuesEnumi  a	  Optional. Lock Hint for the request, it can only be used with read-
write transactions.

Values:
  LOCK_HINT_UNSPECIFIED: Default value. `LOCK_HINT_UNSPECIFIED` is
    equivalent to `LOCK_HINT_SHARED`.
  LOCK_HINT_SHARED: Acquire shared locks. By default when you perform a
    read as part of a read-write transaction, Spanner acquires shared read
    locks, which allows other reads to still access the data until your
    transaction is ready to commit. When your transaction is committing
    and writes are being applied, the transaction attempts to upgrade to
    an exclusive lock for any data you are writing. For more information
    about locks, see [Lock
    modes](https://cloud.google.com/spanner/docs/introspection/lock-
    statistics#explain-lock-modes).
  LOCK_HINT_EXCLUSIVE: Acquire exclusive locks. Requesting exclusive locks
    is beneficial if you observe high write contention, which means you
    notice that multiple transactions are concurrently trying to read and
    write to the same data, resulting in a large number of aborts. This
    problem occurs when two transactions initially acquire shared locks
    and then both try to upgrade to exclusive locks at the same time. In
    this situation both transactions are waiting for the other to give up
    their lock, resulting in a deadlocked situation. Spanner is able to
    detect this occurring and force one of the transactions to abort.
    However, this is a slow and expensive operation and results in lower
    performance. In this case it makes sense to acquire exclusive locks at
    the start of the transaction because then when multiple transactions
    try to act on the same data, they automatically get serialized. Each
    transaction waits its turn to acquire the lock and avoids getting into
    deadlock situations. Because the exclusive lock hint is just a hint,
    it shouldn't be considered equivalent to a mutex. In other words, you
    shouldn't use Spanner exclusive locks as a mutual exclusion mechanism
    for the execution of code outside of Spanner. **Note:** Request
    exclusive locks judiciously because they block others from reading
    that data for the entire transaction, rather than just when the writes
    are being performed. Unless you observe high write contention, you
    should use the default of shared read locks so you don't prematurely
    block other clients from reading the data that you're writing to.
r   r   r   r   N)	r   r   r   r   r   LOCK_HINT_UNSPECIFIEDLOCK_HINT_SHAREDLOCK_HINT_EXCLUSIVEr   r   r    r!   LockHintValueValuesEnumr    s    &N r    r  c                   $    \ rS rSrSrSrSrSrSrg)"ReadRequest.OrderByValueValuesEnumi  a  Optional. Order for the returned rows. By default, Spanner returns
result rows in primary key order except for PartitionRead requests. For
applications that don't require rows to be returned in primary key
(`ORDER_BY_PRIMARY_KEY`) order, setting `ORDER_BY_NO_ORDER` option allows
Spanner to optimize row retrieval, resulting in lower latencies in certain
cases (for example, bulk point lookups).

Values:
  ORDER_BY_UNSPECIFIED: Default value. `ORDER_BY_UNSPECIFIED` is
    equivalent to `ORDER_BY_PRIMARY_KEY`.
  ORDER_BY_PRIMARY_KEY: Read rows are returned in primary key order. In
    the event that this option is used in conjunction with the
    `partition_token` field, the API returns an `INVALID_ARGUMENT` error.
  ORDER_BY_NO_ORDER: Read rows are returned in any order.
r   r   r   r   N)	r   r   r   r   r   ORDER_BY_UNSPECIFIEDORDER_BY_PRIMARY_KEYORDER_BY_NO_ORDERr   r   r    r!   OrderByValueValuesEnumr    s     r    r  r   Tr$   r   r  r+   rY   r  rb   r   r   r   r   r   r   r   r   r  r   r   N)r   r   r   r   r   r   r   r  r  r   rw  r;   r	  r(   r
  rx  r  rc   limitr   lockHintorderByr.   r  r   r  r  r  r   r   r    r!   r  r    s   9v*	 *Xy~~ ( !!!d3'++A.!../DaH



"%!!(A.&

 
 
#%  !:A>( 8!<'''*.))*:B?.$$R(+



#%&&'<bA+r    r  c                       \ rS rSrSr " S S\R                  5      r\R                  " S5      r	\R                  " SS5      rSrg)		ReadWritei  a  Message type to initiate a read-write transaction. Currently this
transaction type has no options.

Enums:
  ReadLockModeValueValuesEnum: Read lock mode for the transaction.

Fields:
  multiplexedSessionPreviousTransactionId: Optional. Clients should pass the
    transaction ID of the previous transaction attempt that was aborted if
    this transaction is being executed on a multiplexed session.
  readLockMode: Read lock mode for the transaction.
c                   $    \ rS rSrSrSrSrSrSrg)%ReadWrite.ReadLockModeValueValuesEnumi  a  Read lock mode for the transaction.

Values:
  READ_LOCK_MODE_UNSPECIFIED: Default value. * If isolation level is
    REPEATABLE_READ, then it is an error to specify `read_lock_mode`.
    Locking semantics default to `OPTIMISTIC`. No validation checks are
    done for reads, except to validate that the data that was served at
    the snapshot time is unchanged at commit time in the following cases:
    1. reads done as part of queries that use `SELECT FOR UPDATE` 2. reads
    done as part of statements with a `LOCK_SCANNED_RANGES` hint 3. reads
    done as part of DML statements * At all other isolation levels, if
    `read_lock_mode` is the default value, then pessimistic read locks are
    used.
  PESSIMISTIC: Pessimistic lock mode. Read locks are acquired immediately
    on read. Semantics described only applies to SERIALIZABLE isolation.
  OPTIMISTIC: Optimistic lock mode. Locks for reads within the transaction
    are not acquired on read. Instead the locks are acquired on a commit
    to validate that read/queried data has not changed since the
    transaction started. Semantics described only applies to SERIALIZABLE
    isolation.
r   r   r   r   N)	r   r   r   r   r   READ_LOCK_MODE_UNSPECIFIEDPESSIMISTIC
OPTIMISTICr   r   r    r!   ReadLockModeValueValuesEnumr    s    * "#KJr    r  r   r   r   N)r   r   r   r   r   r   r   r  r.   'multiplexedSessionPreviousTransactionIdr   readLockModer   r   r    r!   r  r    s=    INN 4 -6,@,@,C)$$%BAF,r    r  c                       \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " S\R                  R                  S9r
\R                  " SS5      rSrg	)
rs  i8  ac  ReplicaComputeCapacity describes the amount of server resources that are
allocated to each replica identified by the replica selection.

Fields:
  nodeCount: The number of nodes allocated to each replica. This may be zero
    in API responses for instances that are not yet in state `READY`.
  processingUnits: The number of processing units allocated to each replica.
    This may be zero in API responses for instances that are not yet in
    state `READY`.
  replicaSelection: Required. Identifies replicas by specified properties.
    All replicas in the selection have the same amount of compute capacity.
r   r`   r   rQ   r+   r   N)r   r   r   r   r   r   rc   rd   re   r~  r  r(   rS   r   r   r    r!   rs  rs  8  sY     $$Q	0A0A0G0GH)**1i6G6G6M6MN/++,FJr    rs  c                       \ rS rSrSr " S S\R                  5      r\R                  " S5      r	\R                  " S5      r\R                  " SS5      rSrg	)
r  iK  a  A ReplicaInfo object.

Enums:
  TypeValueValuesEnum: The type of replica.

Fields:
  defaultLeaderLocation: If true, this location is designated as the default
    leader location where leader replicas are placed. See the [region types
    documentation](https://cloud.google.com/spanner/docs/instances#region_ty
    pes) for more details.
  location: The location of the serving resources, e.g., "us-central1".
  type: The type of replica.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	ReplicaInfo.TypeValueValuesEnumiZ  aQ  The type of replica.

Values:
  TYPE_UNSPECIFIED: Not specified.
  READ_WRITE: Read-write replicas support both reads and writes. These
    replicas: * Maintain a full copy of your data. * Serve reads. * Can
    vote whether to commit a write. * Participate in leadership election.
    * Are eligible to become a leader.
  READ_ONLY: Read-only replicas only support reads (not writes). Read-only
    replicas: * Maintain a full copy of your data. * Serve reads. * Do not
    participate in voting to commit writes. * Are not eligible to become a
    leader.
  WITNESS: Witness replicas don't support reads but do participate in
    voting to commit writes. Witness replicas: * Do not maintain a full
    copy of data. * Do not serve reads. * Vote whether to commit writes. *
    Participate in leader election but are not eligible to become leader.
r   r   r   r+   r   N)
r   r   r   r   r   r  
READ_WRITE	READ_ONLYWITNESSr   r   r    r!   TypeValueValuesEnumr  Z  s    " JIGr    r  r   r   r+   r   N)r   r   r   r   r   r   r   r  r;   defaultLeaderLocationr   r  r   r   r   r   r    r!   r  r  K  sM    INN . $003""1%(			2A	6$r    r  c                       \ rS rSrSr " S S\R                  5      r\R                  " S5      r	\R                  " SS5      rSrg)	r  iv  aL  The directed read replica selector. Callers must provide one or more of
the following fields for replica selection: * `location` - The location must
be one of the regions within the multi-region configuration of your
database. * `type` - The type of the replica. Some examples of using
replica_selectors are: * `location:us-east1` --> The "us-east1" replica(s)
of any available type is used to process the request. * `type:READ_ONLY` -->
The "READ_ONLY" type replica(s) in the nearest available location are used
to process the request. * `location:us-east1 type:READ_ONLY` --> The
"READ_ONLY" type replica(s) in location "us-east1" is used to process the
request.

Enums:
  TypeValueValuesEnum: The type of replica.

Fields:
  location: The location or region of the serving requests, for example,
    "us-east1".
  type: The type of replica.
c                   $    \ rS rSrSrSrSrSrSrg)$ReplicaSelection.TypeValueValuesEnumi  zThe type of replica.

Values:
  TYPE_UNSPECIFIED: Not specified.
  READ_WRITE: Read-write replicas support both reads and writes.
  READ_ONLY: Read-only replicas only support reads (not writes).
r   r   r   r   N)	r   r   r   r   r   r  r  r  r   r   r    r!   r  r    s     JIr    r  r   r   r   N)r   r   r   r   r   r   r   r  r   r  r   r   r   r   r    r!   r  r  v  s<    (
INN 
 ""1%(			2A	6$r    r  c                       \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	\R                  " SS5      r\R                  " S5      r\R                  " S	5      rS
rg)r   i  a  Common request options for various APIs.

Enums:
  PriorityValueValuesEnum: Priority for the request.

Fields:
  clientContext: Optional. Optional context that may be needed for some
    requests.
  priority: Priority for the request.
  requestTag: A per-request tag which can be applied to queries or reads,
    used for statistics collection. Both `request_tag` and `transaction_tag`
    can be specified for a read or query that belongs to a transaction. This
    field is ignored for requests where it's not applicable (for example,
    `CommitRequest`). Legal characters for `request_tag` values are all
    printable characters (ASCII 32 - 126) and the length of a request_tag is
    limited to 50 characters. Values that exceed this limit are truncated.
    Any leading underscore (_) characters are removed from the string.
  transactionTag: A tag used for statistics collection about this
    transaction. Both `request_tag` and `transaction_tag` can be specified
    for a read or query that belongs to a transaction. The value of
    transaction_tag should be the same for all requests belonging to the
    same transaction. If this request doesn't belong to any transaction,
    `transaction_tag` is ignored. Legal characters for `transaction_tag`
    values are all printable characters (ASCII 32 - 126) and the length of a
    `transaction_tag` is limited to 50 characters. Values that exceed this
    limit are truncated. Any leading underscore (_) characters are removed
    from the string.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	&RequestOptions.PriorityValueValuesEnumi  aC  Priority for the request.

Values:
  PRIORITY_UNSPECIFIED: `PRIORITY_UNSPECIFIED` is equivalent to
    `PRIORITY_HIGH`.
  PRIORITY_LOW: This specifies that the request is low priority.
  PRIORITY_MEDIUM: This specifies that the request is medium priority.
  PRIORITY_HIGH: This specifies that the request is high priority.
r   r   r   r+   r   N)
r   r   r   r   r   PRIORITY_UNSPECIFIEDPRIORITY_LOWPRIORITY_MEDIUMPRIORITY_HIGHr   r   r    r!   PriorityValueValuesEnumr    s     LOMr    r  r   r   r   r+   rY   r   N)r   r   r   r   r   r   r   r  r(   clientContextr   priorityr   
requestTagr  r   r   r    r!   r   r     s^    :	  ((!<-  !:A>($$Q'*((+.r    r   c                       \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	\R                  " S5      r\R                  " SSS	9rS
rg)RestoreDatabaseEncryptionConfigi  a  Encryption configuration for the restored database.

Enums:
  EncryptionTypeValueValuesEnum: Required. The encryption type of the
    restored database.

Fields:
  encryptionType: Required. The encryption type of the restored database.
  kmsKeyName: Optional. This field is maintained for backwards
    compatibility. For new callers, we recommend using `kms_key_names` to
    specify the KMS key. Only use `kms_key_name` if the location of the KMS
    key matches the database instance's configuration (location) exactly.
    For example, if the KMS location is in `us-central1` or `nam3`, then the
    database instance must also be in `us-central1` or `nam3`. The Cloud KMS
    key that is used to encrypt and decrypt the restored database. Set this
    field only when encryption_type is `CUSTOMER_MANAGED_ENCRYPTION`. Values
    are of the form `projects//locations//keyRings//cryptoKeys/`.
  kmsKeyNames: Optional. Specifies the KMS configuration for one or more
    keys used to encrypt the database. Values have the form
    `projects//locations//keyRings//cryptoKeys/`. The keys referenced by
    `kms_key_names` must fully cover all regions of the database's instance
    configuration. Some examples: * For regional (single-region) instance
    configurations, specify a regional location KMS key. * For multi-region
    instance configurations of type `GOOGLE_MANAGED`, either specify a
    multi-region location KMS key or multiple regional location KMS keys
    that cover all regions in the instance configuration. * For an instance
    configuration of type `USER_MANAGED`, specify only regional location KMS
    keys to cover each region in the instance configuration. Multi-region
    location KMS keys aren't supported for `USER_MANAGED` type instance
    configurations.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	=RestoreDatabaseEncryptionConfig.EncryptionTypeValueValuesEnumi  a  Required. The encryption type of the restored database.

Values:
  ENCRYPTION_TYPE_UNSPECIFIED: Unspecified. Do not use.
  USE_CONFIG_DEFAULT_OR_BACKUP_ENCRYPTION: This is the default option when
    encryption_config is not specified.
  GOOGLE_DEFAULT_ENCRYPTION: Use Google default encryption.
  CUSTOMER_MANAGED_ENCRYPTION: Use customer managed encryption. If
    specified, `kms_key_name` must must contain a valid Cloud KMS key.
r   r   r   r+   r   Nr/  r   r    r!   r4  r    s!    	 #$./+ !"#r    r4  r   r   r+   Tr$   r   Nr5  r   r    r!   r  r    sO    @$inn $  &&'FJ.$$Q'*%%a$7+r    r  c                       \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	\R                  " S5      r\R                  " S5      r\R                  " S	5      r\R                  " S
S5      r\R                  " SS5      rSrg)RestoreDatabaseMetadatai  a  Metadata type for the long-running operation returned by
RestoreDatabase.

Enums:
  SourceTypeValueValuesEnum: The type of the restore source.

Fields:
  backupInfo: Information about the backup used to restore the database.
  cancelTime: The time at which cancellation of this operation was received.
    Operations.CancelOperation starts asynchronous cancellation on a long-
    running operation. The server makes a best effort to cancel the
    operation, but success is not guaranteed. Clients can use
    Operations.GetOperation or other methods to check whether the
    cancellation succeeded or whether the operation completed despite
    cancellation. On successful cancellation, the operation is not deleted;
    instead, it becomes an operation with an Operation.error value with a
    google.rpc.Status.code of 1, corresponding to `Code.CANCELLED`.
  name: Name of the database being created and restored to.
  optimizeDatabaseOperationName: If exists, the name of the long-running
    operation that will be used to track the post-restore optimization
    process to optimize the performance of the restored database, and remove
    the dependency on the restore source. The name is of the form
    `projects//instances//databases//operations/` where the is the name of
    database being created and restored to. The metadata type of the long-
    running operation is OptimizeRestoredDatabaseMetadata. This long-running
    operation will be automatically created by the system after the
    RestoreDatabase long-running operation completes successfully. This
    operation will not be created if the restore was not successful.
  progress: The progress of the RestoreDatabase operation.
  sourceType: The type of the restore source.
c                        \ rS rSrSrSrSrSrg)1RestoreDatabaseMetadata.SourceTypeValueValuesEnumi%  The type of the restore source.

Values:
  TYPE_UNSPECIFIED: No restore associated.
  BACKUP: A backup was used as the source of the restore.
r   r   r   Nr   r   r   r   r   r  BACKUPr   r   r    r!   SourceTypeValueValuesEnumr  %       Fr    r  r   r   r   r+   rY   r  rb   r   r   N)r   r   r   r   r   r   r   r  r(   
backupInfor   r  rB   optimizeDatabaseOperationNamer  r   
sourceTyper   r   r    r!   r  r    s    @)..  %%lA6*$$Q'*			q	!$"+"7"7":##$7;(""#>B*r    r  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " SS5      r
Srg)	RestoreDatabaseRequesti7  a  The request for RestoreDatabase.

Fields:
  backup: Name of the backup from which to restore. Values are of the form
    `projects//instances//backups/`.
  databaseId: Required. The id of the database to create and restore to.
    This database must not already exist. The `database_id` appended to
    `parent` forms the full database name of the form
    `projects//instances//databases/`.
  encryptionConfig: Optional. An encryption configuration describing the
    encryption type and key resources in Cloud KMS used to encrypt/decrypt
    the database to restore to. If this field is not specified, the restored
    database will use the same encryption configuration as the backup by
    default, namely encryption_type =
    `USE_CONFIG_DEFAULT_OR_BACKUP_ENCRYPTION`.
r   r   r  r+   r   N)r   r   r   r   r   r   r   r   r  r(   r   r   r   r    r!   r  r  7  s=    "   #&$$Q'*++,MqQr    r  c                       \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	\R                  " SS5      rSrg	)
r  iN  a  Information about the database restore.

Enums:
  SourceTypeValueValuesEnum: The type of the restore source.

Fields:
  backupInfo: Information about the backup used to restore the database. The
    backup may no longer exist.
  sourceType: The type of the restore source.
c                        \ rS rSrSrSrSrSrg)%RestoreInfo.SourceTypeValueValuesEnumiZ  r  r   r   r   Nr  r   r    r!   r  r  Z  r  r    r  r   r   r   r   N)r   r   r   r   r   r   r   r  r(   r   r   r  r   r   r    r!   r  r  N  s>    	)..  %%lA6*""#>B*r    r  c                       \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	\R                  " SS5      r
\R                  " SS	S
S9r\R                  " SS5      rSrg)r  ih  aJ  Results from Read or ExecuteSql.

Messages:
  RowsValueListEntry: Single entry in a RowsValue.

Fields:
  metadata: Metadata about the result set, such as row type information.
  precommitToken: Optional. A precommit token is included if the read-write
    transaction is on a multiplexed session. Pass the precommit token with
    the highest sequence number from this transaction attempt to the Commit
    request for this transaction.
  rows: Each element in `rows` is a row whose format is defined by
    metadata.row_type. The ith element in each row matches the ith field in
    metadata.row_type. Elements are encoded based on type as described here.
  stats: Query plan and execution statistics for the SQL statement that
    produced this result set. These can be requested by setting
    ExecuteSqlRequest.query_mode. DML statements always produce stats
    containing the number of rows modified, unless executed using the
    ExecuteSqlRequest.QueryMode.PLAN ExecuteSqlRequest.query_mode. Other
    fields might or might not be populated, based on the
    ExecuteSqlRequest.query_mode.
c                   <    \ rS rSrSr\R                  " SSSS9rSrg)	ResultSet.RowsValueListEntryi  zRSingle entry in a RowsValue.

Fields:
  entry: A extra_types.JsonValue attribute.
r  r   Tr$   r   Nr  r   r    r!   RowsValueListEntryr
    r  r    r  rY  r   r  r   r+   Tr$   rZ  rY   r   N)r   r   r   r   r   r   r'   r  r(   rR  r	  r&  r\  r   r   r    r!   r  r  h  sk    .N9,, N ##$7;())*LaP.			 4a$	G$

 
 !11
5%r    r  c                       \ rS rSrSr\R                  " SS5      r\R                  " SS5      r\R                  " SS5      r	Sr
g	)
rY  i  a  Metadata about a ResultSet or PartialResultSet.

Fields:
  rowType: Indicates the field names and types for the rows in the result
    set. For example, a SQL query like `"SELECT UserId, UserName FROM
    Users"` could return a `row_type` value like: "fields": [ { "name":
    "UserId", "type": { "code": "INT64" } }, { "name": "UserName", "type": {
    "code": "STRING" } }, ]
  transaction: If the read or SQL query began a transaction as a side-
    effect, the information about the new transaction is yielded here.
  undeclaredParameters: A SQL query can be parameterized. In PLAN mode,
    these parameters can be undeclared. This indicates the field names and
    types for those undeclared parameters in the SQL query. For example, a
    SQL query like `"SELECT * FROM Users where UserId = @userId and UserName
    = @userName "` could return a `undeclared_parameters` value like:
    "fields": [ { "name": "UserId", "type": { "code": "INT64" } }, { "name":
    "UserName", "type": { "code": "STRING" } }, ]

StructTyper   r{  r   r+   r   N)r   r   r   r   r   r   r(   rowTyper  undeclaredParametersr   r   r    r!   rY  rY    s@    & ""<3'&&}a8+"//a@r    rY  c                       \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " SS5      r\R                  " SS5      r\R                  " S	5      r\R                  " S
5      rSrg)rZ  i  a{  Additional statistics about a ResultSet or PartialResultSet.

Messages:
  QueryStatsValue: Aggregated statistics from the execution of the query.
    Only present when the query is profiled. For example, a query could
    return the statistics as follows: { "rows_returned": "3",
    "elapsed_time": "1.22 secs", "cpu_time": "1.19 secs" }

Fields:
  queryPlan: QueryPlan for the query associated with this result.
  queryStats: Aggregated statistics from the execution of the query. Only
    present when the query is profiled. For example, a query could return
    the statistics as follows: { "rows_returned": "3", "elapsed_time": "1.22
    secs", "cpu_time": "1.19 secs" }
  rowCountExact: Standard DML returns an exact count of rows that were
    modified.
  rowCountLowerBound: Partitioned DML doesn't offer exactly-once semantics,
    so it returns a lower bound of the rows modified.
r   c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
ResultSetStats.QueryStatsValuei  a}  Aggregated statistics from the execution of the query. Only present
when the query is profiled. For example, a query could return the
statistics as follows: { "rows_returned": "3", "elapsed_time": "1.22
secs", "cpu_time": "1.19 secs" }

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

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

Fields:
  key: Name of the additional property.
  value: A extra_types.JsonValue attribute.
r   r  r   r   Nr  r   r    r!   r"   r    r  r    r"   r   Tr$   r   Nr&   r   r    r!   QueryStatsValuer    r  r    r  r  r   r   r+   rY   r   N)r   r   r   r   r   r   r,   r   r'   r  r(   	queryPlan
queryStatsrc   rowCountExactrowCountLowerBoundr   r   r    r!   rZ  rZ    s    ( !!"89Z	)) Z :Z4 $$[!4)%%&7;*((+- --a0r    rZ  c                   <    \ rS rSrSr\R                  " S5      rSrg)RollbackRequesti  z\The request for Rollback.

Fields:
  transactionId: Required. The transaction to roll back.
r   r   N)	r   r   r   r   r   r   r.   r  r   r   r    r!   r  r    s     &&q)-r    r  c                   $   \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " SS5      r\R                  " S5      r\R                  " S5      r\R                  " S	S
5      r\R                  " S5      rSrg)r  i  as  Scan is a structure which describes Cloud Key Visualizer scan
information.

Messages:
  DetailsValue: Additional information provided by the implementer.

Fields:
  details: Additional information provided by the implementer.
  endTime: The upper bound for when the scan is defined.
  name: The unique name of the scan, specific to the Database service
    implementing this interface.
  scanData: Output only. Cloud Key Visualizer scan data. Note, this field is
    not available to the ListScans method.
  startTime: A range of time (inclusive) for when the scan is defined. The
    lower bound for when the scan is defined.
r   c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
Scan.DetailsValuei  zAdditional information provided by the implementer.

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

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

Fields:
  key: Name of the additional property.
  value: A extra_types.JsonValue attribute.
r   r  r   r   Nr  r   r    r!   r"   r     r  r    r"   r   Tr$   r   Nr&   r   r    r!   DetailsValuer    s4    	AY.. 	A %112FTXYr    r!  r   r   r+   ScanDatarY   rb   r   N)r   r   r   r   r   r   r,   r   r'   r!  r(   detailsr   r   rB   scanDatar   r   r   r    r!   r  r    s    " !!"89ZY&& Z :Z0 "">15'!!!$'			q	!$##J2(##A&)r    r  c                       \ rS rSrSr\R                  " SS5      r\R                  " S5      r	\R                  " S5      r
Srg)	r"  i  a  ScanData contains Cloud Key Visualizer scan data used by the caller to
construct a visualization.

Fields:
  data: Cloud Key Visualizer scan data. The range of time this information
    covers is captured via the above time range fields. Note, this field is
    not available to the ListScans method.
  endTime: The upper bound for when the contained data is defined.
  startTime: A range of time (inclusive) for when the contained data is
    defined. The lower bound for when the contained data is defined.
VisualizationDatar   r   r+   r   N)r   r   r   r   r   r   r(   datar   r   r   r   r   r    r!   r"  r"    s<    
 
		 3Q	7$!!!$'##A&)r    r"  c                   F   \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                  " SS	5      r\R                   " S
5      r\R                  " S5      rSrg)r   i,  a  A session in the Cloud Spanner API.

Messages:
  LabelsValue: The labels for the session. * Label keys must be between 1
    and 63 characters long and must conform to the following regular
    expression: `[a-z]([-a-z0-9]*[a-z0-9])?`. * Label values must be between
    0 and 63 characters long and must conform to the regular expression
    `([a-z]([-a-z0-9]*[a-z0-9])?)?`. * No more than 64 labels can be
    associated with a given session. See https://goo.gl/xmQnxf for more
    information on and examples of labels.

Fields:
  approximateLastUseTime: Output only. The approximate timestamp when the
    session is last used. It's typically earlier than the actual last use
    time.
  createTime: Output only. The timestamp when the session is created.
  creatorRole: The database role which created this session.
  labels: The labels for the session. * Label keys must be between 1 and 63
    characters long and must conform to the following regular expression:
    `[a-z]([-a-z0-9]*[a-z0-9])?`. * Label values must be between 0 and 63
    characters long and must conform to the regular expression
    `([a-z]([-a-z0-9]*[a-z0-9])?)?`. * No more than 64 labels can be
    associated with a given session. See https://goo.gl/xmQnxf for more
    information on and examples of labels.
  multiplexed: Optional. If `true`, specifies a multiplexed session. Use a
    multiplexed session for multiple, concurrent operations including any
    combination of read-only and read-write transactions. Use
    `sessions.create` to create multiplexed sessions. Don't use
    BatchCreateSessions to create a multiplexed session. You can't delete or
    list multiplexed sessions.
  name: Output only. The name of the session. This is always system-
    assigned.
r   c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
Session.LabelsValueiO  aR  The labels for the session. * Label keys must be between 1 and 63
characters long and must conform to the following regular expression:
`[a-z]([-a-z0-9]*[a-z0-9])?`. * Label values must be between 0 and 63
characters long and must conform to the regular expression
`([a-z]([-a-z0-9]*[a-z0-9])?)?`. * No more than 64 labels can be
associated with a given session. See https://goo.gl/xmQnxf for more
information on and examples of labels.

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

Fields:
  additionalProperties: Additional properties of type LabelsValue
c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)&Session.LabelsValue.AdditionalPropertyi`  rl  r   r   r   Nr   r   r    r!   r"   r,  `  r#   r    r"   r   Tr$   r   Nr&   r   r    r!   rm  r*  O  s2    	'Y.. 	' %112FTXYr    rm  r   r   r+   rY   rb   r   r   N)r   r   r   r   r   r   r,   r   r'   rm  r   approximateLastUseTimer   creatorRoler(   r}  r;   multiplexedrB   r   r   r    r!   r   r   ,  s     D !!"89ZI%% Z :Z: %003$$Q'*%%a(+!!-3&&&q)+			q	!$r    r   c                   >    \ rS rSrSr\R                  " SS5      rSrg)SetIamPolicyRequestiu  a)  Request message for `SetIamPolicy` method.

Fields:
  policy: REQUIRED: The complete policy to be applied to the `resource`. The
    size of the policy is limited to a few 10s of KB. An empty policy is a
    valid policy but certain Google Cloud services (such as Projects) might
    reject them.
r  r   r   N)	r   r   r   r   r   r   r(   policyr   r   r    r!   r1  r1  u  s     !!(A.&r    r1  c                       \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " S5      r\R                  " SS5      rSrg	)
r  i  aH  Condensed representation of a node and its subtree. Only present for
`SCALAR` PlanNode(s).

Messages:
  SubqueriesValue: A mapping of (subquery variable name) -> (subquery node
    id) for cases where the `description` string of this node references a
    `SCALAR` subquery contained in the expression subtree rooted at this
    node. The referenced `SCALAR` subquery may not necessarily be a direct
    child of this node.

Fields:
  description: A string representation of the expression subtree rooted at
    this node.
  subqueries: A mapping of (subquery variable name) -> (subquery node id)
    for cases where the `description` string of this node references a
    `SCALAR` subquery contained in the expression subtree rooted at this
    node. The referenced `SCALAR` subquery may not necessarily be a direct
    child of this node.
r   c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
#ShortRepresentation.SubqueriesValuei  a  A mapping of (subquery variable name) -> (subquery node id) for cases
where the `description` string of this node references a `SCALAR` subquery
contained in the expression subtree rooted at this node. The referenced
`SCALAR` subquery may not necessarily be a direct child of this node.

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

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

Fields:
  key: Name of the additional property.
  value: A integer attribute.
r   r   r`   r   Nr;  r   r    r!   r"   r7    r<  r    r"   r   Tr$   r   Nr&   r   r    r!   SubqueriesValuer5    s4    
	IY.. 	I %112FTXYr    r8  r   r   r   N)r   r   r   r   r   r   r,   r   r'   r8  r   r  r(   
subqueriesr   r   r    r!   r  r    s\    ( !!"89Z	)) Z :Z4 %%a(+%%&7;*r    r  c                   <    \ rS rSrSr\R                  " S5      rSrg)r  i  a  Message type for a single-region quorum.

Fields:
  servingLocation: Required. The location of the serving region, for
    example, "us-central1". The location must be one of the regions within
    the dual-region instance configuration of your database. The list of
    valid locations is available using the GetInstanceConfig API. This
    should only be used if you plan to change quorum to the single-region
    quorum type.
r   r   N)	r   r   r   r   r   r   r   servingLocationr   r   r    r!   r  r    s    	 ))!,/r    r  c                       \ rS rSrSr\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " S5      r\R                  " SSS	9rS
rg)2SpannerProjectsInstanceConfigOperationsListRequesti  a@	  A SpannerProjectsInstanceConfigOperationsListRequest object.

Fields:
  filter: An expression that filters the list of returned operations. A
    filter expression consists of a field name, a comparison operator, and a
    value for filtering. The value must be a string, a number, or a boolean.
    The comparison operator must be one of: `<`, `>`, `<=`, `>=`, `!=`, `=`,
    or `:`. Colon `:` is the contains operator. Filter rules are not case
    sensitive. The following fields in the Operation are eligible for
    filtering: * `name` - The name of the long-running operation * `done` -
    False if the operation is in progress, else true. * `metadata.@type` -
    the type of metadata. For example, the type string for
    CreateInstanceConfigMetadata is `type.googleapis.com/google.spanner.admi
    n.instance.v1.CreateInstanceConfigMetadata`. * `metadata.` - any field
    in metadata.value. `metadata.@type` must be specified first, if
    filtering on metadata fields. * `error` - Error associated with the
    long-running operation. * `response.@type` - the type of response. *
    `response.` - any field in response.value. You can combine multiple
    expressions by enclosing each expression in parentheses. By default,
    expressions are combined with AND logic. However, you can specify AND,
    OR, and NOT logic explicitly. Here are a few examples: * `done:true` -
    The operation is complete. * `(metadata.@type=` \ `type.googleapis.com/g
    oogle.spanner.admin.instance.v1.CreateInstanceConfigMetadata) AND` \
    `(metadata.instance_config.name:custom-config) AND` \
    `(metadata.progress.start_time < \"2021-03-28T14:50:00Z\") AND` \
    `(error:*)` - Return operations where: * The operation's metadata type
    is CreateInstanceConfigMetadata. * The instance configuration name
    contains "custom-config". * The operation started before
    2021-03-28T14:50:00Z. * The operation resulted in an error.
  pageSize: Number of operations to be returned in the response. If 0 or
    less, defaults to the server's maximum allowed page size.
  pageToken: If non-empty, `page_token` should contain a next_page_token
    from a previous ListInstanceConfigOperationsResponse to the same
    `parent` and with the same `filter`.
  parent: Required. The project of the instance configuration operations.
    Values are of the form `projects/`.
r   r   r`   r+   rY   Trequiredr   Nr   r   r   r   r   r   r   filterrc   rd   re   pageSize	pageTokenparentr   r   r    r!   r=  r=    sZ    $L   #&##Ay/@/@/F/FG(##A&)  T2&r    r=  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
+SpannerProjectsInstanceConfigsCreateRequesti  a.  A SpannerProjectsInstanceConfigsCreateRequest object.

Fields:
  createInstanceConfigRequest: A CreateInstanceConfigRequest resource to be
    passed as the request body.
  parent: Required. The name of the project in which to create the instance
    configuration. Values are of the form `projects/`.
r[  r   r   Tr>  r   N)r   r   r   r   r   r   r(   createInstanceConfigRequestr   rD  r   r   r    r!   rF  rF    s0     !* 6 67TVW X  T2&r    rF  c                       \ rS rSrSr\R                  " S5      r\R                  " SSS9r\R                  " S5      r
Srg	)
+SpannerProjectsInstanceConfigsDeleteRequesti   a  A SpannerProjectsInstanceConfigsDeleteRequest object.

Fields:
  etag: Used for optimistic concurrency control as a way to help prevent
    simultaneous deletes of an instance configuration from overwriting each
    other. If not empty, the API only deletes the instance configuration
    when the etag provided matches the current status of the requested
    instance configuration. Otherwise, deletes the instance configuration
    without checking the current status of the requested instance
    configuration.
  name: Required. The name of the instance configuration to be deleted.
    Values are of the form `projects//instanceConfigs/`
  validateOnly: An option to validate, but not actually execute, a request,
    and provide the same response.
r   r   Tr>  r+   r   N)r   r   r   r   r   r   r   r   rB   r;   r]  r   r   r    r!   rI  rI     s;      
		q	!$			q4	0$''*,r    rI  c                   :    \ rS rSrSr\R                  " SSS9rSrg)(SpannerProjectsInstanceConfigsGetRequesti  zA SpannerProjectsInstanceConfigsGetRequest object.

Fields:
  name: Required. The name of the requested instance configuration. Values
    are of the form `projects//instanceConfigs/`.
r   Tr>  r   NrA   r   r    r!   rK  rK         
		q4	0$r    rK  c                       \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " S5      r\R                  " SSS9rS	rg
))SpannerProjectsInstanceConfigsListRequesti!  a  A SpannerProjectsInstanceConfigsListRequest object.

Fields:
  pageSize: Number of instance configurations to be returned in the
    response. If 0 or less, defaults to the server's maximum allowed page
    size.
  pageToken: If non-empty, `page_token` should contain a next_page_token
    from a previous ListInstanceConfigsResponse.
  parent: Required. The name of the project for which a list of supported
    instance configurations is requested. Values are of the form
    `projects/`.
r   r`   r   r+   Tr>  r   Nr   r   r   r   r   r   rc   rd   re   rB  r   rC  rD  r   r   r    r!   rN  rN  !  I     ##Ay/@/@/F/FG(##A&)  T2&r    rN  c                   :    \ rS rSrSr\R                  " SSS9rSrg)5SpannerProjectsInstanceConfigsOperationsCancelRequesti4  zA SpannerProjectsInstanceConfigsOperationsCancelRequest object.

Fields:
  name: The name of the operation resource to be cancelled.
r   Tr>  r   NrA   r   r    r!   rR  rR  4       
		q4	0$r    rR  c                   :    \ rS rSrSr\R                  " SSS9rSrg)5SpannerProjectsInstanceConfigsOperationsDeleteRequesti>  zA SpannerProjectsInstanceConfigsOperationsDeleteRequest object.

Fields:
  name: The name of the operation resource to be deleted.
r   Tr>  r   NrA   r   r    r!   rU  rU  >  rS  r    rU  c                   :    \ rS rSrSr\R                  " SSS9rSrg)2SpannerProjectsInstanceConfigsOperationsGetRequestiH  zrA SpannerProjectsInstanceConfigsOperationsGetRequest object.

Fields:
  name: The name of the operation resource.
r   Tr>  r   NrA   r   r    r!   rW  rW  H  rS  r    rW  c                       \ rS rSrSr\R                  " S5      r\R                  " SSS9r\R                  " S\R                  R                  S9r\R                  " S	5      r\R                  " S
5      rSrg)3SpannerProjectsInstanceConfigsOperationsListRequestiR  a  A SpannerProjectsInstanceConfigsOperationsListRequest object.

Fields:
  filter: The standard list filter.
  name: The name of the operation's parent resource.
  pageSize: The standard list page size.
  pageToken: The standard list page token.
  returnPartialSuccess: When set to `true`, operations that are reachable
    are returned as normal, and those that are unreachable are returned in
    the [ListOperationsResponse.unreachable] field. This can only be `true`
    when reading across collections e.g. when `parent` is set to
    `"projects/example/locations/-"`. This field is not by default supported
    and will result in an `UNIMPLEMENTED` error if set unless explicitly
    documented otherwise in service or product specific documentation.
r   r   Tr>  r+   r`   rY   rb   r   Nr   r   r   r   r   r   r   rA  rB   rc   rd   re   rB  rC  r;   returnPartialSuccessr   r   r    r!   rY  rY  R  j        #&			q4	0$##Ay/@/@/F/FG(##A&)"//2r    rY  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
*SpannerProjectsInstanceConfigsPatchRequestij  a^  A SpannerProjectsInstanceConfigsPatchRequest object.

Fields:
  name: A unique identifier for the instance configuration. Values are of
    the form `projects//instanceConfigs/a-z*`. User instance configuration
    must start with `custom-`.
  updateInstanceConfigRequest: A UpdateInstanceConfigRequest resource to be
    passed as the request body.
r   Tr>  UpdateInstanceConfigRequestr   r   N)r   r   r   r   r   r   r   rB   r(   updateInstanceConfigRequestr   r   r    r!   r^  r^  j  s0     
		q4	0$ ) 6 67TVW Xr    r^  c                   :    \ rS rSrSr\R                  " SSS9rSrg)1SpannerProjectsInstanceConfigsSsdCachesGetRequestiy  zA SpannerProjectsInstanceConfigsSsdCachesGetRequest object.

Fields:
  name: Required. The name of the requested SSD cache. Values are of the
    form `projects//instanceConfigs//ssdCaches/`.
r   Tr>  r   NrA   r   r    r!   rb  rb  y  rL  r    rb  c                       \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " S5      r\R                  " SSS9rS	rg
)2SpannerProjectsInstanceConfigsSsdCachesListRequesti  a  A SpannerProjectsInstanceConfigsSsdCachesListRequest object.

Fields:
  pageSize: Optional. Number of SSD caches to be returned in the response.
    If 0 or less, defaults to the server's maximum allowed page size.
  pageToken: Optional. If non-empty, `page_token` should contain a
    next_page_token from a previous ListSsdCachesResponse.
  parent: Required. The name of the instance configuration for which a list
    of SSD caches is requested. Values are of the form
    `projects//instanceConfigs/`.
r   r`   r   r+   Tr>  r   NrO  r   r    r!   rd  rd    sI    
 ##Ay/@/@/F/FG(##A&)  T2&r    rd  c                   :    \ rS rSrSr\R                  " SSS9rSrg)>SpannerProjectsInstanceConfigsSsdCachesOperationsCancelRequesti  zA SpannerProjectsInstanceConfigsSsdCachesOperationsCancelRequest object.

Fields:
  name: The name of the operation resource to be cancelled.
r   Tr>  r   NrA   r   r    r!   rf  rf    rS  r    rf  c                   :    \ rS rSrSr\R                  " SSS9rSrg)>SpannerProjectsInstanceConfigsSsdCachesOperationsDeleteRequesti  zA SpannerProjectsInstanceConfigsSsdCachesOperationsDeleteRequest object.

Fields:
  name: The name of the operation resource to be deleted.
r   Tr>  r   NrA   r   r    r!   rh  rh    rS  r    rh  c                   :    \ rS rSrSr\R                  " SSS9rSrg);SpannerProjectsInstanceConfigsSsdCachesOperationsGetRequesti  z{A SpannerProjectsInstanceConfigsSsdCachesOperationsGetRequest object.

Fields:
  name: The name of the operation resource.
r   Tr>  r   NrA   r   r    r!   rj  rj    rS  r    rj  c                       \ rS rSrSr\R                  " S5      r\R                  " SSS9r\R                  " S\R                  R                  S9r\R                  " S	5      r\R                  " S
5      rSrg)<SpannerProjectsInstanceConfigsSsdCachesOperationsListRequesti  a  A SpannerProjectsInstanceConfigsSsdCachesOperationsListRequest object.

Fields:
  filter: The standard list filter.
  name: The name of the operation's parent resource.
  pageSize: The standard list page size.
  pageToken: The standard list page token.
  returnPartialSuccess: When set to `true`, operations that are reachable
    are returned as normal, and those that are unreachable are returned in
    the [ListOperationsResponse.unreachable] field. This can only be `true`
    when reading across collections e.g. when `parent` is set to
    `"projects/example/locations/-"`. This field is not by default supported
    and will result in an `UNIMPLEMENTED` error if set unless explicitly
    documented otherwise in service or product specific documentation.
r   r   Tr>  r+   r`   rY   rb   r   NrZ  r   r    r!   rl  rl    r\  r    rl  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
3SpannerProjectsInstanceConfigsSsdCachesPatchRequesti  a  A SpannerProjectsInstanceConfigsSsdCachesPatchRequest object.

Fields:
  name: A unique identifier for the cache. Values are of the form
    `projects//instanceConfigs//ssdCaches/a-z*[a-z0-9]`. The final segment
    of the name must be between 2 and 64 characters in length. A cache's
    name cannot be changed after the cache is created.
  updateSsdCacheRequest: A UpdateSsdCacheRequest resource to be passed as
    the request body.
r   Tr>  UpdateSsdCacheRequestr   r   N)r   r   r   r   r   r   r   rB   r(   updateSsdCacheRequestr   r   r    r!   rn  rn    /    	 
		q4	0$#001H!Lr    rn  c                       \ rS rSrSr\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " S5      r\R                  " SSS	9rS
rg)3SpannerProjectsInstancesBackupOperationsListRequesti  a  A SpannerProjectsInstancesBackupOperationsListRequest object.

Fields:
  filter: An expression that filters the list of returned backup operations.
    A filter expression consists of a field name, a comparison operator, and
    a value for filtering. The value must be a string, a number, or a
    boolean. The comparison operator must be one of: `<`, `>`, `<=`, `>=`,
    `!=`, `=`, or `:`. Colon `:` is the contains operator. Filter rules are
    not case sensitive. The following fields in the operation are eligible
    for filtering: * `name` - The name of the long-running operation *
    `done` - False if the operation is in progress, else true. *
    `metadata.@type` - the type of metadata. For example, the type string
    for CreateBackupMetadata is `type.googleapis.com/google.spanner.admin.da
    tabase.v1.CreateBackupMetadata`. * `metadata.` - any field in
    metadata.value. `metadata.@type` must be specified first if filtering on
    metadata fields. * `error` - Error associated with the long-running
    operation. * `response.@type` - the type of response. * `response.` -
    any field in response.value. You can combine multiple expressions by
    enclosing each expression in parentheses. By default, expressions are
    combined with AND logic, but you can specify AND, OR, and NOT logic
    explicitly. Here are a few examples: * `done:true` - The operation is
    complete. * `(metadata.@type=type.googleapis.com/google.spanner.admin.da
    tabase.v1.CreateBackupMetadata) AND` \ `metadata.database:prod` -
    Returns operations where: * The operation's metadata type is
    CreateBackupMetadata. * The source database name of backup contains the
    string "prod". * `(metadata.@type=type.googleapis.com/google.spanner.adm
    in.database.v1.CreateBackupMetadata) AND` \ `(metadata.name:howl) AND` \
    `(metadata.progress.start_time < \"2018-03-28T14:50:00Z\") AND` \
    `(error:*)` - Returns operations where: * The operation's metadata type
    is CreateBackupMetadata. * The backup name contains the string "howl". *
    The operation started before 2018-03-28T14:50:00Z. * The operation
    resulted in an error. * `(metadata.@type=type.googleapis.com/google.span
    ner.admin.database.v1.CopyBackupMetadata) AND` \
    `(metadata.source_backup:test) AND` \ `(metadata.progress.start_time <
    \"2022-01-18T14:50:00Z\") AND` \ `(error:*)` - Returns operations where:
    * The operation's metadata type is CopyBackupMetadata. * The source
    backup name contains the string "test". * The operation started before
    2022-01-18T14:50:00Z. * The operation resulted in an error. * `((metadat
    a.@type=type.googleapis.com/google.spanner.admin.database.v1.CreateBacku
    pMetadata) AND` \ `(metadata.database:test_db)) OR` \ `((metadata.@type=
    type.googleapis.com/google.spanner.admin.database.v1.CopyBackupMetadata)
    AND` \ `(metadata.source_backup:test_bkp)) AND` \ `(error:*)` - Returns
    operations where: * The operation's metadata matches either of criteria:
    * The operation's metadata type is CreateBackupMetadata AND the source
    database name of the backup contains the string "test_db" * The
    operation's metadata type is CopyBackupMetadata AND the source backup
    name contains the string "test_bkp" * The operation resulted in an
    error.
  pageSize: Number of operations to be returned in the response. If 0 or
    less, defaults to the server's maximum allowed page size.
  pageToken: If non-empty, `page_token` should contain a next_page_token
    from a previous ListBackupOperationsResponse to the same `parent` and
    with the same `filter`.
  parent: Required. The instance of the backup operations. Values are of the
    form `projects//instances/`.
r   r   r`   r+   rY   Tr>  r   Nr@  r   r    r!   rs  rs    sZ    7r   #&##Ay/@/@/F/FG(##A&)  T2&r    rs  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
*SpannerProjectsInstancesBackupsCopyRequesti  a&  A SpannerProjectsInstancesBackupsCopyRequest object.

Fields:
  copyBackupRequest: A CopyBackupRequest resource to be passed as the
    request body.
  parent: Required. The name of the destination instance that will contain
    the backup copy. Values are of the form: `projects//instances/`.
r=  r   r   Tr>  r   N)r   r   r   r   r   r   r(   copyBackupRequestr   rD  r   r   r    r!   ru  ru    s/      ,,-@!D  T2&r    ru  c                      \ rS rSrSr " S S\R                  5      r\R                  " SS5      r	\R                  " S5      r\R                  " SS5      r\R                  " S	5      r\R                  " S
SS9r\R                  " SSS9rSrg),SpannerProjectsInstancesBackupsCreateRequesti*  am	  A SpannerProjectsInstancesBackupsCreateRequest object.

Enums:
  EncryptionConfigEncryptionTypeValueValuesEnum: Required. The encryption
    type of the backup.

Fields:
  backup: A Backup resource to be passed as the request body.
  backupId: Required. The id of the backup to be created. The `backup_id`
    appended to `parent` forms the full backup name of the form
    `projects//instances//backups/`.
  encryptionConfig_encryptionType: Required. The encryption type of the
    backup.
  encryptionConfig_kmsKeyName: Optional. This field is maintained for
    backwards compatibility. For new callers, we recommend using
    `kms_key_names` to specify the KMS key. Only use `kms_key_name` if the
    location of the KMS key matches the database instance's configuration
    (location) exactly. For example, if the KMS location is in `us-central1`
    or `nam3`, then the database instance must also be in `us-central1` or
    `nam3`. The Cloud KMS key that is used to encrypt and decrypt the
    restored database. Set this field only when encryption_type is
    `CUSTOMER_MANAGED_ENCRYPTION`. Values are of the form
    `projects//locations//keyRings//cryptoKeys/`.
  encryptionConfig_kmsKeyNames: Optional. Specifies the KMS configuration
    for the one or more keys used to protect the backup. Values are of the
    form `projects//locations//keyRings//cryptoKeys/`. The keys referenced
    by `kms_key_names` must fully cover all regions of the backup's instance
    configuration. Some examples: * For regional (single-region) instance
    configurations, specify a regional location KMS key. * For multi-region
    instance configurations of type `GOOGLE_MANAGED`, either specify a
    multi-region location KMS key or multiple regional location KMS keys
    that cover all regions in the instance configuration. * For an instance
    configuration of type `USER_MANAGED`, specify only regional location KMS
    keys to cover each region in the instance configuration. Multi-region
    location KMS keys aren't supported for `USER_MANAGED` type instance
    configurations.
  parent: Required. The name of the instance in which the backup is created.
    This must be the same instance that contains the database the backup is
    created from. The backup will be stored in the locations specified in
    the instance configuration of this instance. Values are of the form
    `projects//instances/`.
c                   (    \ rS rSrSrSrSrSrSrSr	g)	ZSpannerProjectsInstancesBackupsCreateRequest.EncryptionConfigEncryptionTypeValueValuesEnumiV  rB  r   r   r   r+   r   NrC  r   r    r!   -EncryptionConfigEncryptionTypeValueValuesEnumrz  V  rE  r    r{  rv   r   r   r+   rY   rb   Tr$   r   r>  r   N)r   r   r   r   r   r   r   r{  r(   r   r   r>  r   encryptionConfig_encryptionTypeencryptionConfig_kmsKeyNameencryptionConfig_kmsKeyNamesrD  r   r   r    r!   rx  rx  *  s    )V$inn $$ !!(A.&""1%($-$7$78gij$k! ) 5 5a 8!*!6!6q4!H  T2&r    rx  c                   :    \ rS rSrSr\R                  " SSS9rSrg),SpannerProjectsInstancesBackupsDeleteRequestip  zA SpannerProjectsInstancesBackupsDeleteRequest object.

Fields:
  name: Required. Name of the backup to delete. Values are of the form
    `projects//instances//backups/`.
r   Tr>  r   NrA   r   r    r!   r  r  p  rL  r    r  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
2SpannerProjectsInstancesBackupsGetIamPolicyRequesti{  a~  A SpannerProjectsInstancesBackupsGetIamPolicyRequest object.

Fields:
  getIamPolicyRequest: A GetIamPolicyRequest resource to be passed as the
    request body.
  resource: REQUIRED: The Cloud Spanner resource for which the policy is
    being retrieved. The format is `projects//instances/` for instance
    resources and `projects//instances//databases/` for database resources.
r(  r   r   Tr>  r   Nr   r   r   r   r   r   r(   getIamPolicyRequestr   resourcer   r   r    r!   r  r  {  /     "../DaH""1t4(r    r  c                   :    \ rS rSrSr\R                  " SSS9rSrg))SpannerProjectsInstancesBackupsGetRequesti  zA SpannerProjectsInstancesBackupsGetRequest object.

Fields:
  name: Required. Name of the backup. Values are of the form
    `projects//instances//backups/`.
r   Tr>  r   NrA   r   r    r!   r  r    rL  r    r  c                       \ rS rSrSr\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " S5      r\R                  " SSS	9rS
rg)*SpannerProjectsInstancesBackupsListRequesti  aq  A SpannerProjectsInstancesBackupsListRequest object.

Fields:
  filter: An expression that filters the list of returned backups. A filter
    expression consists of a field name, a comparison operator, and a value
    for filtering. The value must be a string, a number, or a boolean. The
    comparison operator must be one of: `<`, `>`, `<=`, `>=`, `!=`, `=`, or
    `:`. Colon `:` is the contains operator. Filter rules are not case
    sensitive. The following fields in the Backup are eligible for
    filtering: * `name` * `database` * `state` * `create_time` (and values
    are of the format YYYY-MM-DDTHH:MM:SSZ) * `expire_time` (and values are
    of the format YYYY-MM-DDTHH:MM:SSZ) * `version_time` (and values are of
    the format YYYY-MM-DDTHH:MM:SSZ) * `size_bytes` * `backup_schedules` You
    can combine multiple expressions by enclosing each expression in
    parentheses. By default, expressions are combined with AND logic, but
    you can specify AND, OR, and NOT logic explicitly. Here are a few
    examples: * `name:Howl` - The backup's name contains the string "howl".
    * `database:prod` - The database's name contains the string "prod". *
    `state:CREATING` - The backup is pending creation. * `state:READY` - The
    backup is fully created and ready for use. * `(name:howl) AND
    (create_time < \"2018-03-28T14:50:00Z\")` - The backup name contains the
    string "howl" and `create_time` of the backup is before
    2018-03-28T14:50:00Z. * `expire_time < \"2018-03-28T14:50:00Z\"` - The
    backup `expire_time` is before 2018-03-28T14:50:00Z. * `size_bytes >
    10000000000` - The backup's size is greater than 10GB *
    `backup_schedules:daily` - The backup is created from a schedule with
    "daily" in its name.
  pageSize: Number of backups to be returned in the response. If 0 or less,
    defaults to the server's maximum allowed page size.
  pageToken: If non-empty, `page_token` should contain a next_page_token
    from a previous ListBackupsResponse to the same `parent` and with the
    same `filter`.
  parent: Required. The instance to list backups from. Values are of the
    form `projects//instances/`.
r   r   r`   r+   rY   Tr>  r   Nr@  r   r    r!   r  r    sZ    "H   #&##Ay/@/@/F/FG(##A&)  T2&r    r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)6SpannerProjectsInstancesBackupsOperationsCancelRequesti  zA SpannerProjectsInstancesBackupsOperationsCancelRequest object.

Fields:
  name: The name of the operation resource to be cancelled.
r   Tr>  r   NrA   r   r    r!   r  r    rS  r    r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)6SpannerProjectsInstancesBackupsOperationsDeleteRequesti  zA SpannerProjectsInstancesBackupsOperationsDeleteRequest object.

Fields:
  name: The name of the operation resource to be deleted.
r   Tr>  r   NrA   r   r    r!   r  r    rS  r    r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)3SpannerProjectsInstancesBackupsOperationsGetRequesti  zsA SpannerProjectsInstancesBackupsOperationsGetRequest object.

Fields:
  name: The name of the operation resource.
r   Tr>  r   NrA   r   r    r!   r  r    rS  r    r  c                       \ rS rSrSr\R                  " S5      r\R                  " SSS9r\R                  " S\R                  R                  S9r\R                  " S	5      r\R                  " S
5      rSrg)4SpannerProjectsInstancesBackupsOperationsListRequesti  a  A SpannerProjectsInstancesBackupsOperationsListRequest object.

Fields:
  filter: The standard list filter.
  name: The name of the operation's parent resource.
  pageSize: The standard list page size.
  pageToken: The standard list page token.
  returnPartialSuccess: When set to `true`, operations that are reachable
    are returned as normal, and those that are unreachable are returned in
    the [ListOperationsResponse.unreachable] field. This can only be `true`
    when reading across collections e.g. when `parent` is set to
    `"projects/example/locations/-"`. This field is not by default supported
    and will result in an `UNIMPLEMENTED` error if set unless explicitly
    documented otherwise in service or product specific documentation.
r   r   Tr>  r+   r`   rY   rb   r   NrZ  r   r    r!   r  r    r\  r    r  c                       \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	\R                  " S5      r
S	rg
)+SpannerProjectsInstancesBackupsPatchRequesti  a  A SpannerProjectsInstancesBackupsPatchRequest object.

Fields:
  backup: A Backup resource to be passed as the request body.
  name: Output only for the CreateBackup operation. Required for the
    UpdateBackup operation. A globally unique identifier for the backup
    which cannot be changed. Values are of the form
    `projects//instances//backups/a-z*[a-z0-9]` The final segment of the
    name must be between 2 and 60 characters in length. The backup is stored
    in the location(s) specified in the instance configuration of the
    instance containing the backup, identified by the prefix of the backup
    name of the form `projects//instances/`.
  updateMask: Required. A mask specifying which fields (for example,
    `expire_time`) in the backup resource should be updated. This mask is
    relative to the backup resource, not to the request message. The field
    mask must always be specified; this prevents any future fields from
    being erased accidentally by clients that do not know about them.
rv   r   r   Tr>  r+   r   N)r   r   r   r   r   r   r(   r   r   rB   
updateMaskr   r   r    r!   r  r    s=    & !!(A.&			q4	0$$$Q'*r    r  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
2SpannerProjectsInstancesBackupsSetIamPolicyRequesti  ay  A SpannerProjectsInstancesBackupsSetIamPolicyRequest object.

Fields:
  resource: REQUIRED: The Cloud Spanner resource for which the policy is
    being set. The format is `projects//instances/` for instance resources
    and `projects//instances//databases/` for databases resources.
  setIamPolicyRequest: A SetIamPolicyRequest resource to be passed as the
    request body.
r   Tr>  r1  r   r   Nr   r   r   r   r   r   r   r  r(   setIamPolicyRequestr   r   r    r!   r  r    /     ""1t4(!../DaHr    r  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
8SpannerProjectsInstancesBackupsTestIamPermissionsRequesti  a  A SpannerProjectsInstancesBackupsTestIamPermissionsRequest object.

Fields:
  resource: REQUIRED: The Cloud Spanner resource for which permissions are
    being tested. The format is `projects//instances/` for instance
    resources and `projects//instances//databases/` for database resources.
  testIamPermissionsRequest: A TestIamPermissionsRequest resource to be
    passed as the request body.
r   Tr>  TestIamPermissionsRequestr   r   Nr   r   r   r   r   r   r   r  r(   testIamPermissionsRequestr   r   r    r!   r  r    0     ""1t4('445PRSTr    r  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
%SpannerProjectsInstancesCreateRequesti-  a  A SpannerProjectsInstancesCreateRequest object.

Fields:
  createInstanceRequest: A CreateInstanceRequest resource to be passed as
    the request body.
  parent: Required. The name of the project in which to create the instance.
    Values are of the form `projects/`.
ru  r   r   Tr>  r   N)r   r   r   r   r   r   r(   createInstanceRequestr   rD  r   r   r    r!   r  r  -  /     $001H!L  T2&r    r  c                       \ rS rSrSr\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " S5      r\R                  " SSS	9rS
rg)5SpannerProjectsInstancesDatabaseOperationsListRequesti;  a	  A SpannerProjectsInstancesDatabaseOperationsListRequest object.

Fields:
  filter: An expression that filters the list of returned operations. A
    filter expression consists of a field name, a comparison operator, and a
    value for filtering. The value must be a string, a number, or a boolean.
    The comparison operator must be one of: `<`, `>`, `<=`, `>=`, `!=`, `=`,
    or `:`. Colon `:` is the contains operator. Filter rules are not case
    sensitive. The following fields in the operation are eligible for
    filtering: * `name` - The name of the long-running operation * `done` -
    False if the operation is in progress, else true. * `metadata.@type` -
    the type of metadata. For example, the type string for
    RestoreDatabaseMetadata is `type.googleapis.com/google.spanner.admin.dat
    abase.v1.RestoreDatabaseMetadata`. * `metadata.` - any field in
    metadata.value. `metadata.@type` must be specified first, if filtering
    on metadata fields. * `error` - Error associated with the long-running
    operation. * `response.@type` - the type of response. * `response.` -
    any field in response.value. You can combine multiple expressions by
    enclosing each expression in parentheses. By default, expressions are
    combined with AND logic. However, you can specify AND, OR, and NOT logic
    explicitly. Here are a few examples: * `done:true` - The operation is
    complete. * `(metadata.@type=type.googleapis.com/google.spanner.admin.da
    tabase.v1.RestoreDatabaseMetadata) AND` \ `(metadata.source_type:BACKUP)
    AND` \ `(metadata.backup_info.backup:backup_howl) AND` \
    `(metadata.name:restored_howl) AND` \ `(metadata.progress.start_time <
    \"2018-03-28T14:50:00Z\") AND` \ `(error:*)` - Return operations where:
    * The operation's metadata type is RestoreDatabaseMetadata. * The
    database is restored from a backup. * The backup name contains
    "backup_howl". * The restored database's name contains "restored_howl".
    * The operation started before 2018-03-28T14:50:00Z. * The operation
    resulted in an error.
  pageSize: Number of operations to be returned in the response. If 0 or
    less, defaults to the server's maximum allowed page size.
  pageToken: If non-empty, `page_token` should contain a next_page_token
    from a previous ListDatabaseOperationsResponse to the same `parent` and
    with the same `filter`.
  parent: Required. The instance of the database operations. Values are of
    the form `projects//instances/`.
r   r   r`   r+   rY   Tr>  r   Nr@  r   r    r!   r  r  ;  sZ    &P   #&##Ay/@/@/F/FG(##A&)  T2&r    r  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
6SpannerProjectsInstancesDatabasesAddSplitPointsRequestij  aL  A SpannerProjectsInstancesDatabasesAddSplitPointsRequest object.

Fields:
  addSplitPointsRequest: A AddSplitPointsRequest resource to be passed as
    the request body.
  database: Required. The database on whose tables or indexes the split
    points are to be added. Values are of the form
    `projects//instances//databases/`.
rD   r   r   Tr>  r   N)r   r   r   r   r   r   r(   addSplitPointsRequestr   r   r   r   r    r!   r  r  j  s/     $001H!L""1t4(r    r  c                       \ rS rSrSr\R                  " SS5      r\R                  " S5      r	\R                  " SSS9r
S	rg
)=SpannerProjectsInstancesDatabasesBackupSchedulesCreateRequestiy  a  A SpannerProjectsInstancesDatabasesBackupSchedulesCreateRequest object.

Fields:
  backupSchedule: A BackupSchedule resource to be passed as the request
    body.
  backupScheduleId: Required. The Id to use for the backup schedule. The
    `backup_schedule_id` appended to `parent` forms the full backup schedule
    name of the form `projects//instances//databases//backupSchedules/`.
  parent: Required. The name of the database that this backup schedule
    applies to.
r   r   r   r+   Tr>  r   N)r   r   r   r   r   r   r(   backupScheduler   backupScheduleIdrD  r   r   r    r!   r  r  y  s?    
 ))*:A>.**1-  T2&r    r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)=SpannerProjectsInstancesDatabasesBackupSchedulesDeleteRequesti  zA SpannerProjectsInstancesDatabasesBackupSchedulesDeleteRequest object.

Fields:
  name: Required. The name of the schedule to delete. Values are of the form
    `projects//instances//databases//backupSchedules/`.
r   Tr>  r   NrA   r   r    r!   r  r    rL  r    r  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
CSpannerProjectsInstancesDatabasesBackupSchedulesGetIamPolicyRequesti  a  A SpannerProjectsInstancesDatabasesBackupSchedulesGetIamPolicyRequest
object.

Fields:
  getIamPolicyRequest: A GetIamPolicyRequest resource to be passed as the
    request body.
  resource: REQUIRED: The Cloud Spanner resource for which the policy is
    being retrieved. The format is `projects//instances/` for instance
    resources and `projects//instances//databases/` for database resources.
r(  r   r   Tr>  r   Nr  r   r    r!   r  r    s/    	 "../DaH""1t4(r    r  c                   :    \ rS rSrSr\R                  " SSS9rSrg):SpannerProjectsInstancesDatabasesBackupSchedulesGetRequesti  zA SpannerProjectsInstancesDatabasesBackupSchedulesGetRequest object.

Fields:
  name: Required. The name of the schedule to retrieve. Values are of the
    form `projects//instances//databases//backupSchedules/`.
r   Tr>  r   NrA   r   r    r!   r  r    rL  r    r  c                       \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " S5      r\R                  " SSS9rS	rg
);SpannerProjectsInstancesDatabasesBackupSchedulesListRequesti  a  A SpannerProjectsInstancesDatabasesBackupSchedulesListRequest object.

Fields:
  pageSize: Optional. Number of backup schedules to be returned in the
    response. If 0 or less, defaults to the server's maximum allowed page
    size.
  pageToken: Optional. If non-empty, `page_token` should contain a
    next_page_token from a previous ListBackupSchedulesResponse to the same
    `parent`.
  parent: Required. Database is the parent resource whose backup schedules
    should be listed. Values are of the form projects//instances//databases/
r   r`   r   r+   Tr>  r   NrO  r   r    r!   r  r    rP  r    r  c                       \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	\R                  " S5      r
S	rg
)<SpannerProjectsInstancesDatabasesBackupSchedulesPatchRequesti  aT  A SpannerProjectsInstancesDatabasesBackupSchedulesPatchRequest object.

Fields:
  backupSchedule: A BackupSchedule resource to be passed as the request
    body.
  name: Identifier. Output only for the CreateBackupSchedule operation.
    Required for the UpdateBackupSchedule operation. A globally unique
    identifier for the backup schedule which cannot be changed. Values are
    of the form
    `projects//instances//databases//backupSchedules/a-z*[a-z0-9]` The final
    segment of the name must be between 2 and 60 characters in length.
  updateMask: Required. A mask specifying which fields in the BackupSchedule
    resource should be updated. This mask is relative to the BackupSchedule
    resource, not to the request message. The field mask must always be
    specified; this prevents any future fields from being erased
    accidentally.
r   r   r   Tr>  r+   r   N)r   r   r   r   r   r   r(   r  r   rB   r  r   r   r    r!   r  r    s>    $ ))*:A>.			q4	0$$$Q'*r    r  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
CSpannerProjectsInstancesDatabasesBackupSchedulesSetIamPolicyRequesti  a  A SpannerProjectsInstancesDatabasesBackupSchedulesSetIamPolicyRequest
object.

Fields:
  resource: REQUIRED: The Cloud Spanner resource for which the policy is
    being set. The format is `projects//instances/` for instance resources
    and `projects//instances//databases/` for databases resources.
  setIamPolicyRequest: A SetIamPolicyRequest resource to be passed as the
    request body.
r   Tr>  r1  r   r   Nr  r   r    r!   r  r    s/    	 ""1t4(!../DaHr    r  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
ISpannerProjectsInstancesDatabasesBackupSchedulesTestIamPermissionsRequesti  a  A
SpannerProjectsInstancesDatabasesBackupSchedulesTestIamPermissionsRequest
object.

Fields:
  resource: REQUIRED: The Cloud Spanner resource for which permissions are
    being tested. The format is `projects//instances/` for instance
    resources and `projects//instances//databases/` for database resources.
  testIamPermissionsRequest: A TestIamPermissionsRequest resource to be
    passed as the request body.
r   Tr>  r  r   r   Nr  r   r    r!   r  r    0    
 ""1t4('445PRSTr    r  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
.SpannerProjectsInstancesDatabasesCreateRequesti  a$  A SpannerProjectsInstancesDatabasesCreateRequest object.

Fields:
  createDatabaseRequest: A CreateDatabaseRequest resource to be passed as
    the request body.
  parent: Required. The name of the instance that will serve the new
    database. Values are of the form `projects//instances/`.
rL  r   r   Tr>  r   N)r   r   r   r   r   r   r(   createDatabaseRequestr   rD  r   r   r    r!   r  r    r  r    r  c                       \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " S5      r\R                  " SSS9rS	rg
)9SpannerProjectsInstancesDatabasesDatabaseRolesListRequesti  a  A SpannerProjectsInstancesDatabasesDatabaseRolesListRequest object.

Fields:
  pageSize: Number of database roles to be returned in the response. If 0 or
    less, defaults to the server's maximum allowed page size.
  pageToken: If non-empty, `page_token` should contain a next_page_token
    from a previous ListDatabaseRolesResponse.
  parent: Required. The database whose roles should be listed. Values are of
    the form `projects//instances//databases/`.
r   r`   r   r+   Tr>  r   NrO  r   r    r!   r  r    I    	 ##Ay/@/@/F/FG(##A&)  T2&r    r  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
GSpannerProjectsInstancesDatabasesDatabaseRolesTestIamPermissionsRequesti  a  A
SpannerProjectsInstancesDatabasesDatabaseRolesTestIamPermissionsRequest
object.

Fields:
  resource: REQUIRED: The Cloud Spanner resource for which permissions are
    being tested. The format is `projects//instances/` for instance
    resources and `projects//instances//databases/` for database resources.
  testIamPermissionsRequest: A TestIamPermissionsRequest resource to be
    passed as the request body.
r   Tr>  r  r   r   Nr  r   r    r!   r  r    r  r    r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)4SpannerProjectsInstancesDatabasesDropDatabaseRequesti-  zzA SpannerProjectsInstancesDatabasesDropDatabaseRequest object.

Fields:
  database: Required. The database to be dropped.
r   Tr>  r   NrJ  r   r    r!   r  r  -  s     ""1t4(r    r  c                   :    \ rS rSrSr\R                  " SSS9rSrg).SpannerProjectsInstancesDatabasesGetDdlRequesti7  zA SpannerProjectsInstancesDatabasesGetDdlRequest object.

Fields:
  database: Required. The database whose schema we wish to get. Values are
    of the form `projects//instances//databases/`
r   Tr>  r   NrJ  r   r    r!   r  r  7  s     ""1t4(r    r  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
4SpannerProjectsInstancesDatabasesGetIamPolicyRequestiB  a  A SpannerProjectsInstancesDatabasesGetIamPolicyRequest object.

Fields:
  getIamPolicyRequest: A GetIamPolicyRequest resource to be passed as the
    request body.
  resource: REQUIRED: The Cloud Spanner resource for which the policy is
    being retrieved. The format is `projects//instances/` for instance
    resources and `projects//instances//databases/` for database resources.
r(  r   r   Tr>  r   Nr  r   r    r!   r  r  B  r  r    r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)+SpannerProjectsInstancesDatabasesGetRequestiQ  zA SpannerProjectsInstancesDatabasesGetRequest object.

Fields:
  name: Required. The name of the requested database. Values are of the form
    `projects//instances//databases/`.
r   Tr>  r   NrA   r   r    r!   r  r  Q  rL  r    r  c                       \ rS rSrSr " S S\R                  5      r\R                  " S5      r	\R                  " SSS9r
\R                  " S	5      r\R                  " SS
5      rSrg)0SpannerProjectsInstancesDatabasesGetScansRequesti\  a  A SpannerProjectsInstancesDatabasesGetScansRequest object.

Enums:
  ViewValueValuesEnum: Specifies which parts of the Scan should be returned
    in the response. Note, if left unspecified, the FULL view is assumed.

Fields:
  endTime: The upper bound for the time range to retrieve Scan data for.
  name: Required. The unique name of the scan containing the requested
    information, specific to the Database service implementing this
    interface.
  startTime: These fields restrict the Database-specific information
    returned in the `Scan.data` field. If a `View` is provided that does not
    include the `Scan.data` field, these are ignored. This range of time
    must be entirely contained within the defined time range of the targeted
    scan. The lower bound for the time range to retrieve Scan data for.
  view: Specifies which parts of the Scan should be returned in the
    response. Note, if left unspecified, the FULL view is assumed.
c                   $    \ rS rSrSrSrSrSrSrg)DSpannerProjectsInstancesDatabasesGetScansRequest.ViewValueValuesEnumiq  a  Specifies which parts of the Scan should be returned in the response.
Note, if left unspecified, the FULL view is assumed.

Values:
  VIEW_UNSPECIFIED: Not specified, equivalent to SUMMARY.
  SUMMARY: Server responses only include `name`, `details`, `start_time`
    and `end_time`. The default value. Note, the ListScans method may only
    use this view type, others view types are not supported.
  FULL: Full representation of the scan is returned in the server
    response, including `data`.
r   r   r   r   N	r   r   r   r   r   VIEW_UNSPECIFIEDSUMMARYFULLr   r   r    r!   ViewValueValuesEnumr  q  s    
 GDr    r  r   r   Tr>  r+   rY   r   N)r   r   r   r   r   r   r   r  r   r   rB   r   r   viewr   r   r    r!   r  r  \  s^    (INN   !!!$'			q4	0$##A&)			2A	6$r    r  c                       \ rS rSrSr\R                  " S\R                  R                  S9r	\R                  " S5      r\R                  " SSS9rS	rg
),SpannerProjectsInstancesDatabasesListRequesti  a  A SpannerProjectsInstancesDatabasesListRequest object.

Fields:
  pageSize: Number of databases to be returned in the response. If 0 or
    less, defaults to the server's maximum allowed page size.
  pageToken: If non-empty, `page_token` should contain a next_page_token
    from a previous ListDatabasesResponse.
  parent: Required. The instance whose databases should be listed. Values
    are of the form `projects//instances/`.
r   r`   r   r+   Tr>  r   NrO  r   r    r!   r  r    r  r    r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)8SpannerProjectsInstancesDatabasesOperationsCancelRequesti  zA SpannerProjectsInstancesDatabasesOperationsCancelRequest object.

Fields:
  name: The name of the operation resource to be cancelled.
r   Tr>  r   NrA   r   r    r!   r  r    rS  r    r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)8SpannerProjectsInstancesDatabasesOperationsDeleteRequesti  zA SpannerProjectsInstancesDatabasesOperationsDeleteRequest object.

Fields:
  name: The name of the operation resource to be deleted.
r   Tr>  r   NrA   r   r    r!   r  r    rS  r    r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)5SpannerProjectsInstancesDatabasesOperationsGetRequesti  zuA SpannerProjectsInstancesDatabasesOperationsGetRequest object.

Fields:
  name: The name of the operation resource.
r   Tr>  r   NrA   r   r    r!   r  r    rS  r    r  c                       \ rS rSrSr\R                  " S5      r\R                  " SSS9r\R                  " S\R                  R                  S9r\R                  " S	5      r\R                  " S
5      rSrg)6SpannerProjectsInstancesDatabasesOperationsListRequesti  a  A SpannerProjectsInstancesDatabasesOperationsListRequest object.

Fields:
  filter: The standard list filter.
  name: The name of the operation's parent resource.
  pageSize: The standard list page size.
  pageToken: The standard list page token.
  returnPartialSuccess: When set to `true`, operations that are reachable
    are returned as normal, and those that are unreachable are returned in
    the [ListOperationsResponse.unreachable] field. This can only be `true`
    when reading across collections e.g. when `parent` is set to
    `"projects/example/locations/-"`. This field is not by default supported
    and will result in an `UNIMPLEMENTED` error if set unless explicitly
    documented otherwise in service or product specific documentation.
r   r   Tr>  r+   r`   rY   rb   r   NrZ  r   r    r!   r  r    r\  r    r  c                       \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	\R                  " S5      r
S	rg
)-SpannerProjectsInstancesDatabasesPatchRequesti  a  A SpannerProjectsInstancesDatabasesPatchRequest object.

Fields:
  database: A Database resource to be passed as the request body.
  name: Required. The name of the database. Values are of the form
    `projects//instances//databases/`, where `` is as specified in the
    `CREATE DATABASE` statement. This name can be passed to other API
    methods to identify the database.
  updateMask: Required. The list of fields to update. Currently, only
    `enable_drop_protection` field can be updated.
r  r   r   Tr>  r+   r   N)r   r   r   r   r   r   r(   r   r   rB   r  r   r   r    r!   r  r    s=    
 ##J2(			q4	0$$$Q'*r    r  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
/SpannerProjectsInstancesDatabasesRestoreRequesti  a  A SpannerProjectsInstancesDatabasesRestoreRequest object.

Fields:
  parent: Required. The name of the instance in which to create the restored
    database. This instance must be in the same project and have the same
    instance configuration as the instance containing the source backup.
    Values are of the form `projects//instances/`.
  restoreDatabaseRequest: A RestoreDatabaseRequest resource to be passed as
    the request body.
r   Tr>  r  r   r   N)r   r   r   r   r   r   r   rD  r(   restoreDatabaseRequestr   r   r    r!   r  r    s/    	   T2&$112JANr    r  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
<SpannerProjectsInstancesDatabasesSessionsAdaptMessageRequesti  a  A SpannerProjectsInstancesDatabasesSessionsAdaptMessageRequest object.

Fields:
  adaptMessageRequest: A AdaptMessageRequest resource to be passed as the
    request body.
  name: Required. The database session in which the adapter request is
    processed.
r	   r   r   Tr>  r   N)r   r   r   r   r   r   r(   adaptMessageRequestr   rB   r   r   r    r!   r  r    /     "../DaH			q4	0$r    r  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
7SpannerProjectsInstancesDatabasesSessionsAdapterRequesti  zA SpannerProjectsInstancesDatabasesSessionsAdapterRequest object.

Fields:
  adapterSession: A AdapterSession resource to be passed as the request
    body.
  parent: Required. The database in which the new session is created.
r?   r   r   Tr>  r   N)r   r   r   r   r   r   r(   adapterSessionr   rD  r   r   r    r!   r  r    s.     ))*:A>.  T2&r    r  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
;SpannerProjectsInstancesDatabasesSessionsBatchCreateRequesti  a  A SpannerProjectsInstancesDatabasesSessionsBatchCreateRequest object.

Fields:
  batchCreateSessionsRequest: A BatchCreateSessionsRequest resource to be
    passed as the request body.
  database: Required. The database in which the new sessions are created.
r   r   r   Tr>  r   N)r   r   r   r   r   r   r(   batchCreateSessionsRequestr   r   r   r   r    r!   r  r    s0      )556RTUV""1t4(r    r  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
:SpannerProjectsInstancesDatabasesSessionsBatchWriteRequesti  zA SpannerProjectsInstancesDatabasesSessionsBatchWriteRequest object.

Fields:
  batchWriteRequest: A BatchWriteRequest resource to be passed as the
    request body.
  session: Required. The session in which the batch request is to be run.
r   r   r   Tr>  r   N)r   r   r   r   r   r   r(   batchWriteRequestr   r   r   r   r    r!   r  r    /      ,,-@!D!!!d3'r    r  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
@SpannerProjectsInstancesDatabasesSessionsBeginTransactionRequesti%  zA SpannerProjectsInstancesDatabasesSessionsBeginTransactionRequest
object.

Fields:
  beginTransactionRequest: A BeginTransactionRequest resource to be passed
    as the request body.
  session: Required. The session in which the transaction runs.
r   r   r   Tr>  r   N)r   r   r   r   r   r   r(   beginTransactionRequestr   r   r   r   r    r!   r  r  %  s/     &223LaP!!!d3'r    r  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
6SpannerProjectsInstancesDatabasesSessionsCommitRequesti3  zA SpannerProjectsInstancesDatabasesSessionsCommitRequest object.

Fields:
  commitRequest: A CommitRequest resource to be passed as the request body.
  session: Required. The session in which the transaction to be committed is
    running.
r  r   r   Tr>  r   N)r   r   r   r   r   r   r(   commitRequestr   r   r   r   r    r!   r  r  3  s-     ((!<-!!!d3'r    r  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
6SpannerProjectsInstancesDatabasesSessionsCreateRequesti@  zA SpannerProjectsInstancesDatabasesSessionsCreateRequest object.

Fields:
  createSessionRequest: A CreateSessionRequest resource to be passed as the
    request body.
  database: Required. The database in which the new session is created.
r  r   r   Tr>  r   N)r   r   r   r   r   r   r(   createSessionRequestr   r   r   r   r    r!   r  r  @  s/     #//0FJ""1t4(r    r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)6SpannerProjectsInstancesDatabasesSessionsDeleteRequestiM  zA SpannerProjectsInstancesDatabasesSessionsDeleteRequest object.

Fields:
  name: Required. The name of the session to delete.
r   Tr>  r   NrA   r   r    r!   r  r  M  rS  r    r  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
?SpannerProjectsInstancesDatabasesSessionsExecuteBatchDmlRequestiW  a  A SpannerProjectsInstancesDatabasesSessionsExecuteBatchDmlRequest
object.

Fields:
  executeBatchDmlRequest: A ExecuteBatchDmlRequest resource to be passed as
    the request body.
  session: Required. The session in which the DML statements should be
    performed.
r  r   r   Tr>  r   N)r   r   r   r   r   r   r(   executeBatchDmlRequestr   r   r   r   r    r!   r   r   W  s/     %112JAN!!!d3'r    r   c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
:SpannerProjectsInstancesDatabasesSessionsExecuteSqlRequestif  zA SpannerProjectsInstancesDatabasesSessionsExecuteSqlRequest object.

Fields:
  executeSqlRequest: A ExecuteSqlRequest resource to be passed as the
    request body.
  session: Required. The session in which the SQL query should be performed.
r  r   r   Tr>  r   Nr   r   r   r   r   r   r(   executeSqlRequestr   r   r   r   r    r!   r  r  f  r  r    r  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
CSpannerProjectsInstancesDatabasesSessionsExecuteStreamingSqlRequestis  zA SpannerProjectsInstancesDatabasesSessionsExecuteStreamingSqlRequest
object.

Fields:
  executeSqlRequest: A ExecuteSqlRequest resource to be passed as the
    request body.
  session: Required. The session in which the SQL query should be performed.
r  r   r   Tr>  r   Nr  r   r    r!   r  r  s  s/      ,,-@!D!!!d3'r    r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)3SpannerProjectsInstancesDatabasesSessionsGetRequesti  z~A SpannerProjectsInstancesDatabasesSessionsGetRequest object.

Fields:
  name: Required. The name of the session to retrieve.
r   Tr>  r   NrA   r   r    r!   r	  r	    rS  r    r	  c                       \ rS rSrSr\R                  " SSS9r\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " S	5      rS
rg)4SpannerProjectsInstancesDatabasesSessionsListRequesti  a  A SpannerProjectsInstancesDatabasesSessionsListRequest object.

Fields:
  database: Required. The database in which to list sessions.
  filter: An expression for filtering the results of the request. Filter
    rules are case insensitive. The fields eligible for filtering are: *
    `labels.key` where key is the name of a label Some examples of using
    filters are: * `labels.env:*` --> The session has the label "env". *
    `labels.env:dev` --> The session has the label "env" and the value of
    the label contains the string "dev".
  pageSize: Number of sessions to be returned in the response. If 0 or less,
    defaults to the server's maximum allowed page size.
  pageToken: If non-empty, `page_token` should contain a next_page_token
    from a previous ListSessionsResponse.
r   Tr>  r   r+   r`   rY   r   N)r   r   r   r   r   r   r   r   rA  rc   rd   re   rB  rC  r   r   r    r!   r  r    sY      ""1t4(  #&##Ay/@/@/F/FG(##A&)r    r  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
>SpannerProjectsInstancesDatabasesSessionsPartitionQueryRequesti  zA SpannerProjectsInstancesDatabasesSessionsPartitionQueryRequest object.

Fields:
  partitionQueryRequest: A PartitionQueryRequest resource to be passed as
    the request body.
  session: Required. The session used to create the partitions.
rj  r   r   Tr>  r   N)r   r   r   r   r   r   r(   partitionQueryRequestr   r   r   r   r    r!   r  r    s/     $001H!L!!!d3'r    r  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
=SpannerProjectsInstancesDatabasesSessionsPartitionReadRequesti  zA SpannerProjectsInstancesDatabasesSessionsPartitionReadRequest object.

Fields:
  partitionReadRequest: A PartitionReadRequest resource to be passed as the
    request body.
  session: Required. The session used to create the partitions.
rv  r   r   Tr>  r   N)r   r   r   r   r   r   r(   partitionReadRequestr   r   r   r   r    r!   r  r    s/     #//0FJ!!!d3'r    r  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
4SpannerProjectsInstancesDatabasesSessionsReadRequesti  zA SpannerProjectsInstancesDatabasesSessionsReadRequest object.

Fields:
  readRequest: A ReadRequest resource to be passed as the request body.
  session: Required. The session in which the read should be performed.
r  r   r   Tr>  r   Nr   r   r   r   r   r   r(   readRequestr   r   r   r   r    r!   r  r    -     &&}a8+!!!d3'r    r  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
8SpannerProjectsInstancesDatabasesSessionsRollbackRequesti  zA SpannerProjectsInstancesDatabasesSessionsRollbackRequest object.

Fields:
  rollbackRequest: A RollbackRequest resource to be passed as the request
    body.
  session: Required. The session in which the transaction to roll back is
    running.
r  r   r   Tr>  r   N)r   r   r   r   r   r   r(   rollbackRequestr   r   r   r   r    r!   r  r    s.     **+<a@/!!!d3'r    r  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
=SpannerProjectsInstancesDatabasesSessionsStreamingReadRequesti  zA SpannerProjectsInstancesDatabasesSessionsStreamingReadRequest object.

Fields:
  readRequest: A ReadRequest resource to be passed as the request body.
  session: Required. The session in which the read should be performed.
r  r   r   Tr>  r   Nr  r   r    r!   r  r    r  r    r  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
4SpannerProjectsInstancesDatabasesSetIamPolicyRequesti  a{  A SpannerProjectsInstancesDatabasesSetIamPolicyRequest object.

Fields:
  resource: REQUIRED: The Cloud Spanner resource for which the policy is
    being set. The format is `projects//instances/` for instance resources
    and `projects//instances//databases/` for databases resources.
  setIamPolicyRequest: A SetIamPolicyRequest resource to be passed as the
    request body.
r   Tr>  r1  r   r   Nr  r   r    r!   r  r    r  r    r  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
:SpannerProjectsInstancesDatabasesTestIamPermissionsRequesti  a  A SpannerProjectsInstancesDatabasesTestIamPermissionsRequest object.

Fields:
  resource: REQUIRED: The Cloud Spanner resource for which permissions are
    being tested. The format is `projects//instances/` for instance
    resources and `projects//instances//databases/` for database resources.
  testIamPermissionsRequest: A TestIamPermissionsRequest resource to be
    passed as the request body.
r   Tr>  r  r   r   Nr  r   r    r!   r  r    r  r    r  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
1SpannerProjectsInstancesDatabasesUpdateDdlRequesti   zA SpannerProjectsInstancesDatabasesUpdateDdlRequest object.

Fields:
  database: Required. The database to update.
  updateDatabaseDdlRequest: A UpdateDatabaseDdlRequest resource to be passed
    as the request body.
r   Tr>  UpdateDatabaseDdlRequestr   r   N)r   r   r   r   r   r   r   r   r(   updateDatabaseDdlRequestr   r   r    r!   r!  r!     s0     ""1t4(&334NPQRr    r!  c                   :    \ rS rSrSr\R                  " SSS9rSrg)%SpannerProjectsInstancesDeleteRequesti  zA SpannerProjectsInstancesDeleteRequest object.

Fields:
  name: Required. The name of the instance to be deleted. Values are of the
    form `projects//instances/`
r   Tr>  r   NrA   r   r    r!   r%  r%    rL  r    r%  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
+SpannerProjectsInstancesGetIamPolicyRequesti  aw  A SpannerProjectsInstancesGetIamPolicyRequest object.

Fields:
  getIamPolicyRequest: A GetIamPolicyRequest resource to be passed as the
    request body.
  resource: REQUIRED: The Cloud Spanner resource for which the policy is
    being retrieved. The format is `projects//instances/` for instance
    resources and `projects//instances//databases/` for database resources.
r(  r   r   Tr>  r   Nr  r   r    r!   r'  r'    r  r    r'  c                   ^    \ rS rSrSr\R                  " S5      r\R                  " SSS9rSr	g)	"SpannerProjectsInstancesGetRequesti'  a<  A SpannerProjectsInstancesGetRequest object.

Fields:
  fieldMask: If field_mask is present, specifies the subset of Instance
    fields that should be returned. If absent, all Instance fields are
    returned.
  name: Required. The name of the requested instance. Values are of the form
    `projects//instances/`.
r   r   Tr>  r   N)
r   r   r   r   r   r   r   	fieldMaskrB   r   r   r    r!   r)  r)  '  s+     ##A&)			q4	0$r    r)  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " S5      r\R                  " SS	S
9rSrg)>SpannerProjectsInstancesInstancePartitionOperationsListRequesti6  a
  A SpannerProjectsInstancesInstancePartitionOperationsListRequest object.

Fields:
  filter: Optional. An expression that filters the list of returned
    operations. A filter expression consists of a field name, a comparison
    operator, and a value for filtering. The value must be a string, a
    number, or a boolean. The comparison operator must be one of: `<`, `>`,
    `<=`, `>=`, `!=`, `=`, or `:`. Colon `:` is the contains operator.
    Filter rules are not case sensitive. The following fields in the
    Operation are eligible for filtering: * `name` - The name of the long-
    running operation * `done` - False if the operation is in progress, else
    true. * `metadata.@type` - the type of metadata. For example, the type
    string for CreateInstancePartitionMetadata is `type.googleapis.com/googl
    e.spanner.admin.instance.v1.CreateInstancePartitionMetadata`. *
    `metadata.` - any field in metadata.value. `metadata.@type` must be
    specified first, if filtering on metadata fields. * `error` - Error
    associated with the long-running operation. * `response.@type` - the
    type of response. * `response.` - any field in response.value. You can
    combine multiple expressions by enclosing each expression in
    parentheses. By default, expressions are combined with AND logic.
    However, you can specify AND, OR, and NOT logic explicitly. Here are a
    few examples: * `done:true` - The operation is complete. *
    `(metadata.@type=` \ `type.googleapis.com/google.spanner.admin.instance.
    v1.CreateInstancePartitionMetadata) AND` \
    `(metadata.instance_partition.name:custom-instance-partition) AND` \
    `(metadata.start_time < \"2021-03-28T14:50:00Z\") AND` \ `(error:*)` -
    Return operations where: * The operation's metadata type is
    CreateInstancePartitionMetadata. * The instance partition name contains
    "custom-instance-partition". * The operation started before
    2021-03-28T14:50:00Z. * The operation resulted in an error.
  instancePartitionDeadline: Optional. Deadline used while retrieving
    metadata for instance partition operations. Instance partitions whose
    operation metadata cannot be retrieved within this deadline will be
    added to unreachable_instance_partitions in
    ListInstancePartitionOperationsResponse.
  pageSize: Optional. Number of operations to be returned in the response.
    If 0 or less, defaults to the server's maximum allowed page size.
  pageToken: Optional. If non-empty, `page_token` should contain a
    next_page_token from a previous ListInstancePartitionOperationsResponse
    to the same `parent` and with the same `filter`.
  parent: Required. The parent instance of the instance partition
    operations. Values are of the form `projects//instances/`.
r   r   r+   r`   rY   rb   Tr>  r   N)r   r   r   r   r   r   r   rA  instancePartitionDeadlinerc   rd   re   rB  rC  rD  r   r   r    r!   r,  r,  6  sk    *X   #&'33A6##Ay/@/@/F/FG(##A&)  T2&r    r,  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
7SpannerProjectsInstancesInstancePartitionsCreateRequestij  aH  A SpannerProjectsInstancesInstancePartitionsCreateRequest object.

Fields:
  createInstancePartitionRequest: A CreateInstancePartitionRequest resource
    to be passed as the request body.
  parent: Required. The name of the instance in which to create the instance
    partition. Values are of the form `projects//instances/`.
rr  r   r   Tr>  r   N)r   r   r   r   r   r   r(   createInstancePartitionRequestr   rD  r   r   r    r!   r/  r/  j  s0     $-#9#9:Z\]#^   T2&r    r/  c                   ^    \ rS rSrSr\R                  " S5      r\R                  " SSS9rSr	g)	7SpannerProjectsInstancesInstancePartitionsDeleteRequestix  a#  A SpannerProjectsInstancesInstancePartitionsDeleteRequest object.

Fields:
  etag: Optional. If not empty, the API only deletes the instance partition
    when the etag provided matches the current status of the requested
    instance partition. Otherwise, deletes the instance partition without
    checking the current status of the requested instance partition.
  name: Required. The name of the instance partition to be deleted. Values
    are of the form `projects/{project}/instances/{instance}/instancePartiti
    ons/{instance_partition}`
r   r   Tr>  r   N)
r   r   r   r   r   r   r   r   rB   r   r   r    r!   r2  r2  x  s+    
 
		q	!$			q4	0$r    r2  c                   :    \ rS rSrSr\R                  " SSS9rSrg)4SpannerProjectsInstancesInstancePartitionsGetRequesti  zA SpannerProjectsInstancesInstancePartitionsGetRequest object.

Fields:
  name: Required. The name of the requested instance partition. Values are
    of the form `projects/{project}/instances/{instance}/instancePartitions/
    {instance_partition}`.
r   Tr>  r   NrA   r   r    r!   r4  r4    s     
		q4	0$r    r4  c                       \ rS rSrSr\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " S5      r\R                  " SSS	9rS
rg)5SpannerProjectsInstancesInstancePartitionsListRequesti  aY  A SpannerProjectsInstancesInstancePartitionsListRequest object.

Fields:
  instancePartitionDeadline: Optional. Deadline used while retrieving
    metadata for instance partitions. Instance partitions whose metadata
    cannot be retrieved within this deadline will be added to unreachable in
    ListInstancePartitionsResponse.
  pageSize: Number of instance partitions to be returned in the response. If
    0 or less, defaults to the server's maximum allowed page size.
  pageToken: If non-empty, `page_token` should contain a next_page_token
    from a previous ListInstancePartitionsResponse.
  parent: Required. The instance whose instance partitions should be listed.
    Values are of the form `projects//instances/`. Use `{instance} = '-'` to
    list instance partitions for all Instances in a project, e.g.,
    `projects/myproject/instances/-`.
r   r   r`   r+   rY   Tr>  r   N)r   r   r   r   r   r   r   r-  rc   rd   re   rB  rC  rD  r   r   r    r!   r6  r6    sZ    " (33A6##Ay/@/@/F/FG(##A&)  T2&r    r6  c                   :    \ rS rSrSr\R                  " SSS9rSrg)ASpannerProjectsInstancesInstancePartitionsOperationsCancelRequesti  zA SpannerProjectsInstancesInstancePartitionsOperationsCancelRequest
object.

Fields:
  name: The name of the operation resource to be cancelled.
r   Tr>  r   NrA   r   r    r!   r8  r8    rL  r    r8  c                   :    \ rS rSrSr\R                  " SSS9rSrg)ASpannerProjectsInstancesInstancePartitionsOperationsDeleteRequesti  zA SpannerProjectsInstancesInstancePartitionsOperationsDeleteRequest
object.

Fields:
  name: The name of the operation resource to be deleted.
r   Tr>  r   NrA   r   r    r!   r:  r:    rL  r    r:  c                   :    \ rS rSrSr\R                  " SSS9rSrg)>SpannerProjectsInstancesInstancePartitionsOperationsGetRequesti  z~A SpannerProjectsInstancesInstancePartitionsOperationsGetRequest object.

Fields:
  name: The name of the operation resource.
r   Tr>  r   NrA   r   r    r!   r<  r<    rS  r    r<  c                       \ rS rSrSr\R                  " S5      r\R                  " SSS9r\R                  " S\R                  R                  S9r\R                  " S	5      r\R                  " S
5      rSrg)?SpannerProjectsInstancesInstancePartitionsOperationsListRequesti  a  A SpannerProjectsInstancesInstancePartitionsOperationsListRequest
object.

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

Fields:
  name: Required. A unique identifier for the instance partition. Values are
    of the form `projects//instances//instancePartitions/a-z*[a-z0-9]`. The
    final segment of the name must be between 2 and 64 characters in length.
    An instance partition's name cannot be changed after the instance
    partition is created.
  updateInstancePartitionRequest: A UpdateInstancePartitionRequest resource
    to be passed as the request body.
r   Tr>  UpdateInstancePartitionRequestr   r   N)r   r   r   r   r   r   r   rB   r(   updateInstancePartitionRequestr   r   r    r!   r@  r@    s0    
 
		q4	0$#,#9#9:Z\]#^ r    r@  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " S\R                  R                  S9r\R                  " S5      r\R                  " SS	S
9rSrg)#SpannerProjectsInstancesListRequesti  a}  A SpannerProjectsInstancesListRequest object.

Fields:
  filter: An expression for filtering the results of the request. Filter
    rules are case insensitive. The fields eligible for filtering are: *
    `name` * `display_name` * `labels.key` where key is the name of a label
    Some examples of using filters are: * `name:*` --> The instance has a
    name. * `name:Howl` --> The instance's name contains the string "howl".
    * `name:HOWL` --> Equivalent to above. * `NAME:howl` --> Equivalent to
    above. * `labels.env:*` --> The instance has the label "env". *
    `labels.env:dev` --> The instance has the label "env" and the value of
    the label contains the string "dev". * `name:howl labels.env:dev` -->
    The instance's name contains "howl" and it has the label "env" with its
    value containing "dev".
  instanceDeadline: Deadline used while retrieving metadata for instances.
    Instances whose metadata cannot be retrieved within this deadline will
    be added to unreachable in ListInstancesResponse.
  pageSize: Number of instances to be returned in the response. If 0 or
    less, defaults to the server's maximum allowed page size.
  pageToken: If non-empty, `page_token` should contain a next_page_token
    from a previous ListInstancesResponse.
  parent: Required. The name of the project for which a list of instances is
    requested. Values are of the form `projects/`.
r   r   r+   r`   rY   rb   Tr>  r   N)r   r   r   r   r   r   r   rA  instanceDeadlinerc   rd   re   rB  rC  rD  r   r   r    r!   rD  rD    sj    2   #&**1-##Ay/@/@/F/FG(##A&)  T2&r    rD  c                   `    \ rS rSrSr\R                  " SS5      r\R                  " SSS9r	Sr
g	)
#SpannerProjectsInstancesMoveRequesti  zA SpannerProjectsInstancesMoveRequest object.

Fields:
  moveInstanceRequest: A MoveInstanceRequest resource to be passed as the
    request body.
  name: Required. The instance to move. Values are of the form
    `projects//instances/`.
r3  r   r   Tr>  r   N)r   r   r   r   r   r   r(   moveInstanceRequestr   rB   r   r   r    r!   rG  rG    r  r    rG  c                   :    \ rS rSrSr\R                  " SSS9rSrg)/SpannerProjectsInstancesOperationsCancelRequesti&  zA SpannerProjectsInstancesOperationsCancelRequest object.

Fields:
  name: The name of the operation resource to be cancelled.
r   Tr>  r   NrA   r   r    r!   rJ  rJ  &  rS  r    rJ  c                   :    \ rS rSrSr\R                  " SSS9rSrg)/SpannerProjectsInstancesOperationsDeleteRequesti0  z}A SpannerProjectsInstancesOperationsDeleteRequest object.

Fields:
  name: The name of the operation resource to be deleted.
r   Tr>  r   NrA   r   r    r!   rL  rL  0  rS  r    rL  c                   :    \ rS rSrSr\R                  " SSS9rSrg),SpannerProjectsInstancesOperationsGetRequesti:  zlA SpannerProjectsInstancesOperationsGetRequest object.

Fields:
  name: The name of the operation resource.
r   Tr>  r   NrA   r   r    r!   rN  rN  :  rS  r    rN  c                       \ rS rSrSr\R                  " S5      r\R                  " SSS9r\R                  " S\R                  R                  S9r\R                  " S	5      r\R                  " S
5      rSrg)-SpannerProjectsInstancesOperationsListRequestiD  a  A SpannerProjectsInstancesOperationsListRequest object.

Fields:
  filter: The standard list filter.
  name: The name of the operation's parent resource.
  pageSize: The standard list page size.
  pageToken: The standard list page token.
  returnPartialSuccess: When set to `true`, operations that are reachable
    are returned as normal, and those that are unreachable are returned in
    the [ListOperationsResponse.unreachable] field. This can only be `true`
    when reading across collections e.g. when `parent` is set to
    `"projects/example/locations/-"`. This field is not by default supported
    and will result in an `UNIMPLEMENTED` error if set unless explicitly
    documented otherwise in service or product specific documentation.
r   r   Tr>  r+   r`   rY   rb   r   NrZ  r   r    r!   rP  rP  D  r\  r    rP  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
$SpannerProjectsInstancesPatchRequesti\  a  A SpannerProjectsInstancesPatchRequest object.

Fields:
  name: Required. A unique identifier for the instance, which cannot be
    changed after the instance is created. Values are of the form
    `projects//instances/a-z*[a-z0-9]`. The final segment of the name must
    be between 2 and 64 characters in length.
  updateInstanceRequest: A UpdateInstanceRequest resource to be passed as
    the request body.
r   Tr>  UpdateInstanceRequestr   r   N)r   r   r   r   r   r   r   rB   r(   updateInstanceRequestr   r   r    r!   rR  rR  \  rq  r    rR  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
+SpannerProjectsInstancesSetIamPolicyRequestil  ar  A SpannerProjectsInstancesSetIamPolicyRequest object.

Fields:
  resource: REQUIRED: The Cloud Spanner resource for which the policy is
    being set. The format is `projects//instances/` for instance resources
    and `projects//instances//databases/` for databases resources.
  setIamPolicyRequest: A SetIamPolicyRequest resource to be passed as the
    request body.
r   Tr>  r1  r   r   Nr  r   r    r!   rV  rV  l  r  r    rV  c                   `    \ rS rSrSr\R                  " SSS9r\R                  " SS5      r	Sr
g	)
1SpannerProjectsInstancesTestIamPermissionsRequesti{  a  A SpannerProjectsInstancesTestIamPermissionsRequest object.

Fields:
  resource: REQUIRED: The Cloud Spanner resource for which permissions are
    being tested. The format is `projects//instances/` for instance
    resources and `projects//instances//databases/` for database resources.
  testIamPermissionsRequest: A TestIamPermissionsRequest resource to be
    passed as the request body.
r   Tr>  r  r   r   Nr  r   r    r!   rX  rX  {  r  r    rX  c                      \ rS rSrSr " S S\R                  5      r\R                  " S5      r	\R                  " S\R                  R                  S9r\R                  " S5      r\R                  " S	S
S9r\R                   " SS5      rSrg)SpannerScansListRequesti  ab  A SpannerScansListRequest object.

Enums:
  ViewValueValuesEnum: Specifies which parts of the Scan should be returned
    in the response. Note, only the SUMMARY view (the default) is currently
    supported for ListScans.

Fields:
  filter: A filter expression to restrict the results based on information
    present in the available Scan collection. The filter applies to all
    fields within the Scan message except for `data`.
  pageSize: The maximum number of items to return.
  pageToken: The next_page_token value returned from a previous List
    request, if any.
  parent: Required. The unique name of the parent resource, specific to the
    Database service implementing this interface.
  view: Specifies which parts of the Scan should be returned in the
    response. Note, only the SUMMARY view (the default) is currently
    supported for ListScans.
c                   $    \ rS rSrSrSrSrSrSrg)+SpannerScansListRequest.ViewValueValuesEnumi  a  Specifies which parts of the Scan should be returned in the response.
Note, only the SUMMARY view (the default) is currently supported for
ListScans.

Values:
  VIEW_UNSPECIFIED: Not specified, equivalent to SUMMARY.
  SUMMARY: Server responses only include `name`, `details`, `start_time`
    and `end_time`. The default value. Note, the ListScans method may only
    use this view type, others view types are not supported.
  FULL: Full representation of the scan is returned in the server
    response, including `data`.
r   r   r   r   Nr  r   r    r!   r  r\    s     GDr    r  r   r   r`   r+   rY   Tr>  rb   r   N)r   r   r   r   r   r   r   r  r   rA  rc   rd   re   rB  rC  rD  r   r  r   r   r    r!   rZ  rZ    s|    *INN "   #&##Ay/@/@/F/FG(##A&)  T2&			2A	6$r    rZ  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " SSSS9r
\R                  " S	5      rS
rg)rF   i  a  The split points of a table or an index.

Fields:
  expireTime: Optional. The expiration timestamp of the split points. A
    timestamp in the past means immediate expiration. The maximum value can
    be 30 days in the future. Defaults to 10 days in the future if not
    specified.
  index: The index to split. If specified, the `table` field must refer to
    the index's base table.
  keys: Required. The list of split keys. In essence, the split boundaries.
  table: The table to split.
r   r   r  r+   Tr$   rY   r   N)r   r   r   r   r   r   r   r   rx  r(   r  r  r   r   r    r!   rF   rF     sM     $$Q'*



"%			q4	8$



"%r    rF   c                      \ rS rSrSr " S S\R                  5      r\R                  " S5       " S S\R                  5      5       r\R                  " S5      r\R                  " S	5      r\R                  " SS
5      r\R                  " S5      r\R$                  " S5      r\R(                  " SS5      r\R                  " S5      rSrg)r  i  a  SSD Cache to optimize Disk IO capacity usage when using HDD storage.

Enums:
  StateValueValuesEnum: Output only. The current SsdCache state.

Messages:
  LabelsValue: Cloud Labels are a flexible and lightweight mechanism for
    organizing cloud resources into groups that reflect a customer's
    organizational needs and deployment strategies. Cloud Labels can be used
    to filter collections of resources. They can be used to control how
    resource metrics are aggregated. And they can be used as arguments to
    policy management rules (e.g. route, firewall, load balancing, etc.). *
    Label keys must be between 1 and 63 characters long and must conform to
    the following regular expression: `a-z{0,62}`. * Label values must be
    between 0 and 63 characters long and must conform to the regular
    expression `[a-z0-9_-]{0,63}`. * No more than 64 labels can be
    associated with a given resource. See https://goo.gl/xmQnxf for more
    information on and examples of labels. If you plan to use labels in your
    own code, please note that additional characters may be allowed in the
    future. And so you are advised to use an internal label representation,
    such as JSON, which doesn't rely upon specific characters being
    disallowed. For example, representing labels as the string: name + "_" +
    value would prove problematic if we were to allow "_" in a future
    release.

Fields:
  createTime: Output only. The time at which the SsdCache was created.
  displayName: The name of this cache as it appears in UIs.
  labels: Cloud Labels are a flexible and lightweight mechanism for
    organizing cloud resources into groups that reflect a customer's
    organizational needs and deployment strategies. Cloud Labels can be used
    to filter collections of resources. They can be used to control how
    resource metrics are aggregated. And they can be used as arguments to
    policy management rules (e.g. route, firewall, load balancing, etc.). *
    Label keys must be between 1 and 63 characters long and must conform to
    the following regular expression: `a-z{0,62}`. * Label values must be
    between 0 and 63 characters long and must conform to the regular
    expression `[a-z0-9_-]{0,63}`. * No more than 64 labels can be
    associated with a given resource. See https://goo.gl/xmQnxf for more
    information on and examples of labels. If you plan to use labels in your
    own code, please note that additional characters may be allowed in the
    future. And so you are advised to use an internal label representation,
    such as JSON, which doesn't rely upon specific characters being
    disallowed. For example, representing labels as the string: name + "_" +
    value would prove problematic if we were to allow "_" in a future
    release.
  name: A unique identifier for the cache. Values are of the form
    `projects//instanceConfigs//ssdCaches/a-z*[a-z0-9]`. The final segment
    of the name must be between 2 and 64 characters in length. A cache's
    name cannot be changed after the cache is created.
  sizeGib: Optional. Size of SSD cache in GiB.
  state: Output only. The current SsdCache state.
  updateTime: Output only. The time at which the SsdCache was most recently
    updated.
c                   $    \ rS rSrSrSrSrSrSrg)SsdCache.StateValueValuesEnumi  a  Output only. The current SsdCache state.

Values:
  STATE_UNSPECIFIED: Not specified.
  CREATING: The SsdCache is still being created. Cache resources may not
    be available yet.
  READY: The SsdCache is fully provisioned and ready to be associated with
    Cloud Spanner instances.
r   r   r   r   Nr   r   r    r!   r   r`    r  r    r   r   c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
SsdCache.LabelsValuei  ri  c                   `    \ rS rSrSr\R                  " S5      r\R                  " S5      rSr	g)'SsdCache.LabelsValue.AdditionalPropertyi.  rl  r   r   r   Nr   r   r    r!   r"   rd  .  r#   r    r"   r   Tr$   r   Nr&   r   r    r!   rm  rb    rn  r    rm  r   r   r+   rY   rb   r   r   r   N)r   r   r   r   r   r   r   r   r   r,   r'   rm  r   r   rx  r(   r}  rB   rc   sizeGibr   r   r   r   r   r    r!   r  r    s    6pY^^  !!"89%ZI%% %Z :%ZN $$Q'*%%a(+!!-3&			q	!$""1%'


4a
8%$$Q'*r    r  c                      \ rS rSrSr " S S\R                  5      r " S S\R                  5      r\R                  " SS5      r
\R                  " S5      r\R                  " SS	S
S9r\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                  " S5      r\R$                  " SSS9r\R                  " S5      r\R                  " S5      r\R                  " S5      r\R                  " S5      rSrg)StandardQueryParametersiD  a  Query parameters accepted by all methods.

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

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

Values:
  json: Responses with Content-Type of application/json
  media: Media download with context-dependent Content-Type
  proto: Responses with Content-Type of application/x-protobuf
r   r   r   r   N)	r   r   r   r   r   jsonmediaprotor   r   r    r!   AltValueValuesEnumri  _  s     DEEr    rm  c                        \ rS rSrSrSrSrSrg)-StandardQueryParameters.FXgafvValueValuesEnumik  zFV1 error format.

Values:
  _1: v1 error format
  _2: v2 error format
r   r   r   N)r   r   r   r   r   _1_2r   r   r    r!   FXgafvValueValuesEnumro  k  s     
B	
Br    rr  r   r   r+   rj  )defaultrY   rb   r   r   r   Tr   r   r   r   r   N)r   r   r   r   r   r   r   rm  rr  r   f__xgafvr   access_tokenaltcallbackfieldsr   oauth_tokenr;   prettyPrint	quotaUsertrace
uploadTypeupload_protocolr   r   r    r!   rg  rg  D  s    4
9>> 
inn    !8!<(&&q),0!VD#""1%(  #&a #%%a(+&&q$7+##A&)



#%$$R(*))"-/r    rg  c                   0   \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " S5       " S S\R                  5      5       r
\R                  " SS5      r\R                  " SS	5      r\R                  " S
5      rSrg)r  i  a  A single DML statement.

Messages:
  ParamTypesValue: It isn't always possible for Cloud Spanner to infer the
    right SQL type from a JSON value. For example, values of type `BYTES`
    and values of type `STRING` both appear in params as JSON strings. In
    these cases, `param_types` can be used to specify the exact SQL type for
    some or all of the SQL statement parameters. See the definition of Type
    for more information about SQL types.
  ParamsValue: Parameter names and values that bind to placeholders in the
    DML string. A parameter placeholder consists of the `@` character
    followed by the parameter name (for example, `@firstName`). Parameter
    names can contain letters, numbers, and underscores. Parameters can
    appear anywhere that a literal value is expected. The same parameter
    name can be used more than once, for example: `"WHERE id > @msg_id AND
    id < @msg_id + 100"` It's an error to execute a SQL statement with
    unbound parameters.

Fields:
  paramTypes: It isn't always possible for Cloud Spanner to infer the right
    SQL type from a JSON value. For example, values of type `BYTES` and
    values of type `STRING` both appear in params as JSON strings. In these
    cases, `param_types` can be used to specify the exact SQL type for some
    or all of the SQL statement parameters. See the definition of Type for
    more information about SQL types.
  params: Parameter names and values that bind to placeholders in the DML
    string. A parameter placeholder consists of the `@` character followed
    by the parameter name (for example, `@firstName`). Parameter names can
    contain letters, numbers, and underscores. Parameters can appear
    anywhere that a literal value is expected. The same parameter name can
    be used more than once, for example: `"WHERE id > @msg_id AND id <
    @msg_id + 100"` It's an error to execute a SQL statement with unbound
    parameters.
  sql: Required. The DML string.
r   c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
Statement.ParamTypesValuei  a   It isn't always possible for Cloud Spanner to infer the right SQL type
from a JSON value. For example, values of type `BYTES` and values of type
`STRING` both appear in params as JSON strings. In these cases,
`param_types` can be used to specify the exact SQL type for some or all of
the SQL statement parameters. See the definition of Type for more
information about SQL types.

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

Fields:
  additionalProperties: Additional properties of type ParamTypesValue
c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g),Statement.ParamTypesValue.AdditionalPropertyi  r  r   r  r   r   Nr  r   r    r!   r"   r    r  r    r"   r   Tr$   r   Nr&   r   r    r!   r  r    r  r    r  c                   f    \ rS rSrSr " S S\R                  5      r\R                  " SSSS9r	Sr
g	)
Statement.ParamsValuei  ax  Parameter names and values that bind to placeholders in the DML
string. A parameter placeholder consists of the `@` character followed by
the parameter name (for example, `@firstName`). Parameter names can
contain letters, numbers, and underscores. Parameters can appear anywhere
that a literal value is expected. The same parameter name can be used more
than once, for example: `"WHERE id > @msg_id AND id < @msg_id + 100"` It's
an error to execute a SQL statement with unbound parameters.

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

Fields:
  additionalProperties: Properties of the object.
c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)(Statement.ParamsValue.AdditionalPropertyi  r  r   r  r   r   Nr  r   r    r!   r"   r    r  r    r"   r   Tr$   r   Nr&   r   r    r!   r  r    rs  r    r  r   r   r+   r   N)r   r   r   r   r   r   r,   r   r'   r  r  r(   r  r  r   r  r   r   r    r!   r  r    s    "H !!"89Z	)) Z :Z8 !!"89ZI%% Z :Z: %%&7;*!!-3&a #r    r  c                       \ rS rSrSr\R                  " S5       " S S\R                  5      5       r	\R                  " S\R                  R                  S9r\R                  " SSS	S
9r\R                   " S5      rSrg)r   i  a  The `Status` type defines a logical error model that is suitable for
different programming environments, including REST APIs and RPC APIs. It is
used by [gRPC](https://github.com/grpc). Each `Status` message contains
three pieces of data: error code, error message, and error details. You can
find out more about this error model and how to work with it in the [API
Design Guide](https://cloud.google.com/apis/design/errors).

Messages:
  DetailsValueListEntry: A DetailsValueListEntry object.

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

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

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

Fields:
  key: Name of the additional property.
  value: A extra_types.JsonValue attribute.
r   r  r   r   Nr  r   r    r!   r"   r  	  r  r    r"   r   Tr$   r   Nr&   r   r    r!   DetailsValueListEntryr    s4    		AY.. 	A %112FTXYr    r  r   r`   r   Tr$   r+   r   N)r   r   r   r   r   r   r,   r   r'   r  rc   rd   re   coder(   r#  r   r  r   r   r    r!   r   r     s|    & !!"89Zi// Z :Z2 
		9+<+<+B+B	C$""#:AM'!!!$'r    r   c                   <    \ rS rSrSr\R                  " SSSS9rSrg)	r  i  a  `StructType` defines the fields of a STRUCT type.

Fields:
  fields: The list of fields that make up this struct. Order is significant,
    because values of this struct type are represented as lists, where the
    order of field values matches the order of fields in the StructType. In
    turn, the order of fields matches the order of columns in a read
    request, or the order of fields in the `SELECT` clause of a query.
r  r   Tr$   r   N)	r   r   r   r   r   r   r(   rx  r   r   r    r!   r  r    s     !!'1t<&r    r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)r  i)  zRequest message for `TestIamPermissions` method.

Fields:
  permissions: REQUIRED: The set of permissions to check for 'resource'.
    Permissions with wildcards (such as '*', 'spanner.*',
    'spanner.instances.*') are not allowed.
r   Tr$   r   N	r   r   r   r   r   r   r   permissionsr   r   r    r!   r  r  )  s     %%a$7+r    r  c                   :    \ rS rSrSr\R                  " SSS9rSrg)TestIamPermissionsResponsei5  zResponse message for `TestIamPermissions` method.

Fields:
  permissions: A subset of `TestPermissionsRequest.permissions` that the
    caller is allowed.
r   Tr$   r   Nr  r   r    r!   r  r  5  s     %%a$7+r    r  c                       \ rS rSrSr\R                  " S5      r\R                  " SS5      r	\R                  " S5      rSrg)	r{  i@  a  A transaction.

Fields:
  id: `id` may be used to identify the transaction in subsequent Read,
    ExecuteSql, Commit, or Rollback calls. Single-use read-only transactions
    do not have IDs, because single-use transactions do not support multiple
    requests.
  precommitToken: A precommit token is included in the response of a
    BeginTransaction request if the read-write transaction is on a
    multiplexed session and a mutation_key was specified in the
    BeginTransaction. The precommit token with the highest sequence number
    from this transaction attempt should be passed to the Commit request for
    this transaction.
  readTimestamp: For snapshot read-only transactions, the read timestamp
    chosen for the transaction. Not returned by default: see
    TransactionOptions.ReadOnly.return_read_timestamp. A timestamp in
    RFC3339 UTC \"Zulu\" format, accurate to nanoseconds. Example:
    `"2014-10-02T15:01:23.045123456Z"`.
r   r  r   r+   r   N)r   r   r   r   r   r   r.   idr(   r	  r   r  r   r   r    r!   r{  r{  @  s<    ( A"))*LaP.''*-r    r{  c                       \ rS rSrSr " S S\R                  5      r\R                  " S5      r	\R                  " SS5      r\R                  " SS5      r\R                  " S	S
5      r\R                  " SS5      rSrg)r   iZ  a}  Options to use for transactions.

Enums:
  IsolationLevelValueValuesEnum: Isolation level for the transaction.

Fields:
  excludeTxnFromChangeStreams: When `exclude_txn_from_change_streams` is set
    to `true`, it prevents read or write transactions from being tracked in
    change streams. * If the DDL option `allow_txn_exclusion` is set to
    `true`, then the updates made within this transaction aren't recorded in
    the change stream. * If you don't set the DDL option
    `allow_txn_exclusion` or if it's set to `false`, then the updates made
    within this transaction are recorded in the change stream. When
    `exclude_txn_from_change_streams` is set to `false` or not set,
    modifications from this transaction are recorded in all change streams
    that are tracking columns modified by these transactions. The
    `exclude_txn_from_change_streams` option can only be specified for read-
    write or partitioned DML transactions, otherwise the API returns an
    `INVALID_ARGUMENT` error.
  isolationLevel: Isolation level for the transaction.
  partitionedDml: Partitioned DML transaction. Authorization to begin a
    Partitioned DML transaction requires
    `spanner.databases.beginPartitionedDmlTransaction` permission on the
    `session` resource.
  readOnly: Transaction does not write. Authorization to begin a read-only
    transaction requires `spanner.databases.beginReadOnlyTransaction`
    permission on the `session` resource.
  readWrite: Transaction may write. Authorization to begin a read-write
    transaction requires
    `spanner.databases.beginOrRollbackReadWriteTransaction` permission on
    the `session` resource.
c                   $    \ rS rSrSrSrSrSrSrg)0TransactionOptions.IsolationLevelValueValuesEnumi|  aW  Isolation level for the transaction.

Values:
  ISOLATION_LEVEL_UNSPECIFIED: Default value. If the value is not
    specified, the `SERIALIZABLE` isolation level is used.
  SERIALIZABLE: All transactions appear as if they executed in a serial
    order, even if some of the reads, writes, and other operations of
    distinct transactions actually occurred in parallel. Spanner assigns
    commit timestamps that reflect the order of committed transactions to
    implement this property. Spanner offers a stronger guarantee than
    serializability called external consistency. For more information, see
    [TrueTime and external
    consistency](https://cloud.google.com/spanner/docs/true-time-external-
    consistency#serializability).
  REPEATABLE_READ: All reads performed during the transaction observe a
    consistent snapshot of the database, and the transaction is only
    successfully committed in the absence of conflicts between its updates
    and any concurrent updates that have occurred since that snapshot.
    Consequently, in contrast to `SERIALIZABLE` transactions, only write-
    write conflicts are detected in snapshot transactions. This isolation
    level does not support read-only and partitioned DML transactions.
    When `REPEATABLE_READ` is specified on a read-write transaction, the
    locking semantics default to `OPTIMISTIC`.
r   r   r   r   N)	r   r   r   r   r   ISOLATION_LEVEL_UNSPECIFIEDSERIALIZABLEREPEATABLE_READr   r   r    r!   IsolationLevelValueValuesEnumr  |  s    0 #$LOr    r  r   r   r  r+   r  rY   r  rb   r   N)r   r   r   r   r   r   r   r  r;   r   r   isolationLevelr(   partitionedDmlreadOnly	readWriter   r   r    r!   r   r   Z  su    Binn : !* 6 6q 9&&'FJ.))*:A>.##J2($$[!4)r    r   c                       \ rS rSrSr\R                  " SS5      r\R                  " S5      r	\R                  " SS5      r
Srg)	r  i  aY  This message is used to select the transaction in which a Read or
ExecuteSql call runs. See TransactionOptions for more information about
transactions.

Fields:
  begin: Begin a new transaction and execute this read or SQL query in it.
    The transaction ID of the new transaction is returned in
    ResultSetMetadata.transaction, which is a Transaction.
  id: Execute the read or SQL query in a previously-started transaction.
  singleUse: Execute the read or SQL query in a temporary transaction. This
    is the most efficient way to execute a transaction that consists of a
    single SQL query.
r   r   r   r+   r   N)r   r   r   r   r   r   r(   beginr.   r  	singleUser   r   r    r!   r  r    s?     
 
 !5q
9%A"$$%91=)r    r  c                   (   \ rS rSrSr " S S\R                  5      r " S S\R                  5      r\R                  " S S5      r
\R                  " SS5      r\R                  " S	5      r\R                  " S
S5      r\R                  " SS5      rSrg)r  i  a	  `Type` indicates the type of a Cloud Spanner value, as might be stored
in a table cell or returned from an SQL query.

Enums:
  CodeValueValuesEnum: Required. The TypeCode for this type.
  TypeAnnotationValueValuesEnum: The TypeAnnotationCode that disambiguates
    SQL type that Spanner will use to represent values of this type during
    query processing. This is necessary for some type codes because a single
    TypeCode can be mapped to different SQL types depending on the SQL
    dialect. type_annotation typically is not needed to process the content
    of a value (it doesn't affect serialization) and clients can ignore it
    on the read path.

Fields:
  arrayElementType: If code == ARRAY, then `array_element_type` is the type
    of the array elements.
  code: Required. The TypeCode for this type.
  protoTypeFqn: If code == PROTO or code == ENUM, then `proto_type_fqn` is
    the fully qualified name of the proto type representing the proto/enum
    definition.
  structType: If code == STRUCT, then `struct_type` provides type
    information for the struct's fields.
  typeAnnotation: The TypeAnnotationCode that disambiguates SQL type that
    Spanner will use to represent values of this type during query
    processing. This is necessary for some type codes because a single
    TypeCode can be mapped to different SQL types depending on the SQL
    dialect. type_annotation typically is not needed to process the content
    of a value (it doesn't affect serialization) and clients can ignore it
    on the read path.
c                   \    \ rS rSrSrSrSrSrSrSr	Sr
S	rS
rSrSrSrSrSrSrSrSrSrSrg)Type.CodeValueValuesEnumi  a6	  Required. The TypeCode for this type.

Values:
  TYPE_CODE_UNSPECIFIED: Not specified.
  BOOL: Encoded as JSON `true` or `false`.
  INT64: Encoded as `string`, in decimal format.
  FLOAT64: Encoded as `number`, or the strings `"NaN"`, `"Infinity"`, or
    `"-Infinity"`.
  FLOAT32: Encoded as `number`, or the strings `"NaN"`, `"Infinity"`, or
    `"-Infinity"`.
  TIMESTAMP: Encoded as `string` in RFC 3339 timestamp format. The time
    zone must be present, and must be `"Z"`. If the schema has the column
    option `allow_commit_timestamp=true`, the placeholder string
    `"spanner.commit_timestamp()"` can be used to instruct the system to
    insert the commit timestamp associated with the transaction commit.
  DATE: Encoded as `string` in RFC 3339 date format.
  STRING: Encoded as `string`.
  BYTES: Encoded as a base64-encoded `string`, as described in RFC 4648,
    section 4.
  ARRAY: Encoded as `list`, where the list elements are represented
    according to array_element_type.
  STRUCT: Encoded as `list`, where list element `i` is represented
    according to
    [struct_type.fields[i]][google.spanner.v1.StructType.fields].
  NUMERIC: Encoded as `string`, in decimal format or scientific notation
    format. Decimal format: `[+-]Digits[.[Digits]]` or `+-.Digits`
    Scientific notation:
    `[+-]Digits[.[Digits]][ExponentIndicator[+-]Digits]` or
    `+-.Digits[ExponentIndicator[+-]Digits]` (ExponentIndicator is `"e"`
    or `"E"`)
  JSON: Encoded as a JSON-formatted `string` as described in RFC 7159. The
    following rules are applied when parsing JSON input: - Whitespace
    characters are not preserved. - If a JSON object has duplicate keys,
    only the first key is preserved. - Members of a JSON object are not
    guaranteed to have their order preserved. - JSON array elements will
    have their order preserved.
  PROTO: Encoded as a base64-encoded `string`, as described in RFC 4648,
    section 4.
  ENUM: Encoded as `string`, in decimal format.
  INTERVAL: Encoded as `string`, in `ISO8601` duration format -
    `P[n]Y[n]M[n]DT[n]H[n]M[n[.fraction]]S` where `n` is an integer. For
    example, `P1Y2M3DT4H5M6.5S` represents time duration of 1 year, 2
    months, 3 days, 4 hours, 5 minutes, and 6.5 seconds.
  UUID: Encoded as `string`, in lower-case hexa-decimal format, as
    described in RFC 9562, section 4.
r   r   r   r+   rY   rb   r   r   r   r   r   r   r   r   r   r   r   r   N)r   r   r   r   r   TYPE_CODE_UNSPECIFIEDBOOLINT64FLOAT64FLOAT32	TIMESTAMPDATESTRINGBYTESARRAYSTRUCTNUMERICJSONPROTOENUMINTERVALUUIDr   r   r    r!   CodeValueValuesEnumr    s`    -\ DEGGIDFEEFGDEDHDr    r  c                   (    \ rS rSrSrSrSrSrSrSr	g)	"Type.TypeAnnotationValueValuesEnumi  aj  The TypeAnnotationCode that disambiguates SQL type that Spanner will
use to represent values of this type during query processing. This is
necessary for some type codes because a single TypeCode can be mapped to
different SQL types depending on the SQL dialect. type_annotation
typically is not needed to process the content of a value (it doesn't
affect serialization) and clients can ignore it on the read path.

Values:
  TYPE_ANNOTATION_CODE_UNSPECIFIED: Not specified.
  PG_NUMERIC: PostgreSQL compatible NUMERIC type. This annotation needs to
    be applied to Type instances having NUMERIC type code to specify that
    values of this type should be treated as PostgreSQL NUMERIC values.
    Currently this annotation is always needed for NUMERIC when a client
    interacts with PostgreSQL-enabled Spanner databases.
  PG_JSONB: PostgreSQL compatible JSONB type. This annotation needs to be
    applied to Type instances having JSON type code to specify that values
    of this type should be treated as PostgreSQL JSONB values. Currently
    this annotation is always needed for JSON when a client interacts with
    PostgreSQL-enabled Spanner databases.
  PG_OID: PostgreSQL compatible OID type. This annotation can be used by a
    client interacting with PostgreSQL-enabled Spanner database to specify
    that a value should be treated using the semantics of the OID type.
r   r   r   r+   r   N)
r   r   r   r   r    TYPE_ANNOTATION_CODE_UNSPECIFIED
PG_NUMERICPG_JSONBPG_OIDr   r   r    r!   TypeAnnotationValueValuesEnumr    s    . ()$JHFr    r  r   r   r+   r  rY   rb   r   N)r   r   r   r   r   r   r   r  r  r(   arrayElementTyper   r  r   protoTypeFqn
structTypetypeAnnotationr   r   r    r!   r  r    s    >?INN ?Binn : ++FA6			2A	6$&&q),%%lA6*&&'FJ.r    r  c                       \ rS rSrSr\R                  " SSSS9r\R                  " SSS9r	\R                  " S5      r
\R                  " S	S
SS9r\R                  " SSS9r\R                  " S5      rSrg)UpdateDatabaseDdlMetadatai9  a  Metadata type for the operation returned by UpdateDatabaseDdl.

Fields:
  actions: The brief action info for the DDL statements. `actions[i]` is the
    brief info for `statements[i]`.
  commitTimestamps: Reports the commit timestamps of all statements that
    have succeeded so far, where `commit_timestamps[i]` is the commit
    timestamp for the statement `statements[i]`.
  database: The database being modified.
  progress: The progress of the UpdateDatabaseDdl operations. All DDL
    statements will have continuously updating progress, and `progress[i]`
    is the operation progress for `statements[i]`. Also, `progress[i]` will
    have start time and end time populated with commit timestamp of
    operation, as well as a progress of 100% once the operation has
    completed.
  statements: For an update this list contains all the statements. For an
    individual statement, this list contains only that statement.
  throttled: Output only. When true, indicates that the operation is
    throttled, for example, due to resource constraints. When resources
    become available the operation will resume and this field will be false
    again.
r  r   Tr$   r   r+   r  rY   rb   r   r   N)r   r   r   r   r   r   r(   actionsr   commitTimestampsr   r  r  r;   	throttledr   r   r    r!   r  r  9  sx    . ""#;QN'**1t<""1%(##$7TJ($$Q6*$$Q')r    r  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r	\R                  " SSS9r
Srg	)
r"  iY  a	  Enqueues the given DDL statements to be applied, in order but not
necessarily all at once, to the database schema at some point (or points) in
the future. The server checks that the statements are executable
(syntactically valid, name tables that exist, etc.) before enqueueing them,
but they may still fail upon later execution (for example, if a statement
from another batch of statements is applied first and it conflicts in some
way, or if there is some data-related problem like a `NULL` value in a
column to which `NOT NULL` would be added). If a statement fails, all
subsequent statements in the batch are automatically cancelled. Each batch
of statements is assigned a name which can be used with the Operations API
to monitor progress. See the operation_id field for more details.

Fields:
  operationId: If empty, the new update request is assigned an
    automatically-generated operation ID. Otherwise, `operation_id` is used
    to construct the name of the resulting Operation. Specifying an explicit
    operation ID simplifies determining whether the statements were executed
    in the event that the UpdateDatabaseDdl call is replayed, or the return
    value is otherwise lost: the database and `operation_id` fields can be
    combined to form the `name` of the resulting longrunning.Operation:
    `/operations/`. `operation_id` should be unique within the database, and
    must be a valid identifier: `a-z*`. Note that automatically-generated
    operation IDs always begin with an underscore. If the named operation
    already exists, UpdateDatabaseDdl returns `ALREADY_EXISTS`.
  protoDescriptors: Optional. Proto descriptors used by CREATE/ALTER PROTO
    BUNDLE statements. Contains a protobuf-serialized [google.protobuf.FileD
    escriptorSet](https://github.com/protocolbuffers/protobuf/blob/main/src/
    google/protobuf/descriptor.proto). To generate it,
    [install](https://grpc.io/docs/protoc-installation/) and run `protoc`
    with --include_imports and --descriptor_set_out. For example, to
    generate for moon/shot/app.proto, run ``` $protoc --proto_path=/app_path
    --proto_path=/lib_path \ --include_imports \
    --descriptor_set_out=descriptors.data \ moon/shot/app.proto ``` For more
    details, see protobuffer [self
    description](https://developers.google.com/protocol-
    buffers/docs/techniques#self-description).
  statements: Required. DDL statements to be applied to the database.
r   r   r+   Tr$   r   N)r   r   r   r   r   r   r   operationIdr.   rR  r  r   r   r    r!   r"  r"  Y  s=    %N %%a(+))!,$$Q6*r    r"  c                       \ rS rSrSr\R                  " S5      r\R                  " SS5      r	\R                  " SS5      r
Srg	)
UpdateDatabaseMetadatai  a?  Metadata type for the operation returned by UpdateDatabase.

Fields:
  cancelTime: The time at which this operation was cancelled. If set, this
    operation is in the process of undoing itself (which is best-effort).
  progress: The progress of the UpdateDatabase operation.
  request: The request for UpdateDatabase.
r   r  r   UpdateDatabaseRequestr+   r   N)r   r   r   r   r   r   r   r  r(   r  r   r   r   r    r!   r  r    s?     $$Q'*##$7;(""#:A>'r    r  c                   b    \ rS rSrSr\R                  " SS5      r\R                  " S5      r	Sr
g)r  i  a'  The request for UpdateDatabase.

Fields:
  database: Required. The database to update. The `name` field of the
    database is of the form `projects//instances//databases/`.
  updateMask: Required. The list of fields to update. Currently, only
    `enable_drop_protection` field can be updated.
r  r   r   r   N)r   r   r   r   r   r   r(   r   r   r  r   r   r    r!   r  r    s+     ##J2($$Q'*r    r  c                       \ rS rSrSr\R                  " S5      r\R                  " SS5      r	\R                  " SS5      r
Srg	)
UpdateInstanceConfigMetadatai  a  Metadata type for the operation returned by UpdateInstanceConfig.

Fields:
  cancelTime: The time at which this operation was cancelled.
  instanceConfig: The desired instance configuration after updating.
  progress: The progress of the UpdateInstanceConfig operation.
r   rU  r   rV  r+   r   NrW  r   r    r!   r  r    rY  r    r  c                       \ rS rSrSr\R                  " SS5      r\R                  " S5      r	\R                  " S5      rSrg)	r_  i  a  The request for UpdateInstanceConfig.

Fields:
  instanceConfig: Required. The user instance configuration to update, which
    must always include the instance configuration name. Otherwise, only
    fields mentioned in update_mask need be included. To prevent conflicts
    of concurrent updates, etag can be used.
  updateMask: Required. A mask specifying which fields in InstanceConfig
    should be updated. The field mask must always be specified; this
    prevents any future fields in InstanceConfig from being erased
    accidentally by clients that do not know about them. Only display_name
    and labels can be updated.
  validateOnly: An option to validate, but not actually execute, a request,
    and provide the same response.
rU  r   r   r+   r   N)r   r   r   r   r   r   r(   rX  r   r  r;   r]  r   r   r    r!   r_  r_    s<      ))*:A>.$$Q'*''*,r    r_  c                       \ rS rSrSr " S S\R                  5      r\R                  " S5      r	\R                  " S5      r
\R                  " SS5      r\R                  " SS	5      r\R                  " S
5      rSrg)UpdateInstanceMetadatai  a  Metadata type for the operation returned by UpdateInstance.

Enums:
  ExpectedFulfillmentPeriodValueValuesEnum: The expected fulfillment period
    of this update operation.

Fields:
  cancelTime: The time at which this operation was cancelled. If set, this
    operation is in the process of undoing itself (which is guaranteed to
    succeed) and cannot be cancelled again.
  endTime: The time at which this operation failed or was completed
    successfully.
  expectedFulfillmentPeriod: The expected fulfillment period of this update
    operation.
  instance: The desired end state of the update.
  startTime: The time at which UpdateInstance request was received.
c                   $    \ rS rSrSrSrSrSrSrg)?UpdateInstanceMetadata.ExpectedFulfillmentPeriodValueValuesEnumi  a_  The expected fulfillment period of this update operation.

Values:
  FULFILLMENT_PERIOD_UNSPECIFIED: Not specified.
  FULFILLMENT_PERIOD_NORMAL: Normal fulfillment period. The operation is
    expected to complete within minutes.
  FULFILLMENT_PERIOD_EXTENDED: Extended fulfillment period. It can take up
    to an hour for the operation to complete.
r   r   r   r   Nrb  r   r    r!   rf  r    rg  r    rf  r   r   r+   rh  rY   rb   r   Nri  r   r    r!   r  r    rl  r    r  c                       \ rS rSrSr\R                  " S5      r\R                  " S5      r\R                  " SS5      r
\R                  " S5      rSrg	)
UpdateInstancePartitionMetadatai  a  Metadata type for the operation returned by UpdateInstancePartition.

Fields:
  cancelTime: The time at which this operation was cancelled. If set, this
    operation is in the process of undoing itself (which is guaranteed to
    succeed) and cannot be cancelled again.
  endTime: The time at which this operation failed or was completed
    successfully.
  instancePartition: The desired end state of the update.
  startTime: The time at which UpdateInstancePartition request was received.
r   r   ro  r+   rY   r   Nrp  r   r    r!   r  r    sM    
 $$Q'*!!!$',,-@!D##A&)r    r  c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)rA  i   a  The request for UpdateInstancePartition.

Fields:
  fieldMask: Required. A mask specifying which fields in InstancePartition
    should be updated. The field mask must always be specified; this
    prevents any future fields in InstancePartition from being erased
    accidentally by clients that do not know about them.
  instancePartition: Required. The instance partition to update, which must
    always include the instance partition name. Otherwise, only fields
    mentioned in field_mask need be included.
r   ro  r   r   N)r   r   r   r   r   r   r   r*  r(   r   r   r   r    r!   rA  rA     s-    
 ##A&),,-@!Dr    rA  c                   b    \ rS rSrSr\R                  " S5      r\R                  " SS5      r	Sr
g)rS  i   a  The request for UpdateInstance.

Fields:
  fieldMask: Required. A mask specifying which fields in Instance should be
    updated. The field mask must always be specified; this prevents any
    future fields in Instance from being erased accidentally by clients that
    do not know about them.
  instance: Required. The instance to update, which must always include the
    instance name. Otherwise, only fields mentioned in field_mask need be
    included.
r   rh  r   r   N)r   r   r   r   r   r   r   r*  r(   rk  r   r   r    r!   rS  rS     s+    
 ##A&)##J2(r    rS  c                   b    \ rS rSrSr\R                  " SS5      r\R                  " S5      r	Sr
g)ro  i$   a  The request for UpdateSsdCacheRequest.

Fields:
  ssdCache: Required. The SSD cache to update, which must always include the
    SSD cache name. Otherwise, only fields mentioned in update_mask need be
    included.
  updateMask: Required. A mask specifying which fields in SsdCache should be
    updated. The update mask must always be specified; this prevents any
    future fields in SsdCache from being erased accidentally by clients that
    do not know about them. Only display_name, size_gib and labels can be
    updated.
r  r   r   r   N)r   r   r   r   r   r   r(   r  r   r  r   r   r    r!   ro  ro  $   s+     ##J2($$Q'*r    ro  c                      \ rS rSrSr " S S\R                  5      r\R                  " S5      r	\R                  " S5      r
\R                  " SSS	S
9r\R                  " SS	S
9r\R                  " S5      r\R                  " SS	S
9r\R                  " S5      r\R$                  " SS5      r\R                  " SSS	S
9r\R                  " SSS	S
9rSrg)r&  i6   a  A VisualizationData object.

Enums:
  KeyUnitValueValuesEnum: The unit for the key: e.g. 'key' or 'chunk'.

Fields:
  dataSourceEndToken: The token signifying the end of a data_source.
  dataSourceSeparatorToken: The token delimiting a datasource name from the
    rest of a key in a data_source.
  diagnosticMessages: The list of messages (info, alerts, ...)
  endKeyStrings: We discretize the entire keyspace into buckets. Assuming
    each bucket has an inclusive keyrange and covers keys from k(i) ...
    k(n). In this case k(n) would be an end key for a given range.
    end_key_string is the collection of all such end keys
  hasPii: Whether this scan contains PII.
  indexedKeys: Keys of key ranges that contribute significantly to a given
    metric Can be thought of as heavy hitters.
  keySeparator: The token delimiting the key prefixes.
  keyUnit: The unit for the key: e.g. 'key' or 'chunk'.
  metrics: The list of data objects for each metric.
  prefixNodes: The list of extracted key prefix nodes used in the key prefix
    hierarchy.
c                   $    \ rS rSrSrSrSrSrSrg)(VisualizationData.KeyUnitValueValuesEnumiO   zThe unit for the key: e.g. 'key' or 'chunk'.

Values:
  KEY_UNIT_UNSPECIFIED: Required default value
  KEY: Each entry corresponds to one key
  CHUNK: Each entry corresponds to a chunk of keys
r   r   r   r   N)	r   r   r   r   r   KEY_UNIT_UNSPECIFIEDKEYCHUNKr   r   r    r!   KeyUnitValueValuesEnumr  O   s     
CEr    r  r   r   r  r+   Tr$   rY   rb   r   r   r   r  r   r  r   r   N)r   r   r   r   r   r   r   r  r   dataSourceEndTokendataSourceSeparatorTokenr(   diagnosticMessagesendKeyStringsr;   hasPiiindexedKeyskeySeparatorr   keyUnitmetricsprefixNodesr   r   r    r!   r&  r&  6   s    0
y~~ 
 !,,Q/&2215 --.A1tT''D9-!!!$&%%a$7+&&q), 8!<'""8Q>'&&|R$G+r    r&  c                       \ rS rSrSr " S S\R                  5      r\R                  " SSS9r	\R                  " S5      r
\R                  " SS	SS9rS
rg)r<  ig   a  Arguments to insert, update, insert_or_update, and replace operations.

Messages:
  ValuesValueListEntry: Single entry in a ValuesValue.

Fields:
  columns: The names of the columns in table to be written. The list of
    columns must contain enough columns to allow Cloud Spanner to derive
    values for all primary key columns in the row(s) to be modified.
  table: Required. The table whose rows will be written.
  values: The values to be written. `values` can contain more than one list
    of values. If it does, then multiple rows are written, one for each
    entry in `values`. Each list in `values` must have exactly as many
    entries as there are entries in columns above. Sending multiple lists is
    equivalent to sending multiple `Mutation`s, each containing one `values`
    entry and repeating table and columns. Individual values in each list
    are encoded as described here.
c                   <    \ rS rSrSr\R                  " SSSS9rSrg)	Write.ValuesValueListEntryi{   zTSingle entry in a ValuesValue.

Fields:
  entry: A extra_types.JsonValue attribute.
r  r   Tr$   r   Nr  r   r    r!   ValuesValueListEntryr  {   r  r    r  r   Tr$   r   r+   r   N)r   r   r   r   r   r   r'   r  r   rw  r  r(   r]  r   r   r    r!   r<  r<  g   sT    &NY.. N !!!d3'



"%!!"8!dK&r    r<  rt  z$.xgafvrp  1rq  2r|  zencryptionConfig.encryptionTyper}  zencryptionConfig.kmsKeyNamer~  zencryptionConfig.kmsKeyNamesN()  r   
__future__r   apitools.base.protorpcliter   r   apitools.base.pyr   r   packager'   r	   r2   r?   rD   rJ   rN   rU   rP   rW   rX   rv   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   rG  rI  rL  rT  r[  r_  rn  rr  ru  r  r   r   r  r  r  r  r  r  r  r  r  r  rO  r   r  r  r  r  r   r  r  r   r&  r(  r)  r   r  r   r2  r6  r@  rh  rU  r  rV  ro  rQ   r  r  r  rE  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r%  r  r  r%  r  r*  r0  r3  r7  r  r   r   r  r  rV  rX  r_  r   r   rf  rj  rv  rz  r   r  r  r  r  r  r  r  r  r   r  r  r  rs  r  r  r   r  r  r  r  r  rY  rZ  r  r  r"  r   r1  r  r  r=  rF  rI  rK  rN  rR  rU  rW  rY  r^  rb  rd  rf  rh  rj  rl  rn  rs  ru  rx  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r   r  r  r	  r  r  r  r  r  r  r  r  r!  r%  r'  r)  r,  r/  r2  r4  r6  r8  r:  r<  r>  r@  rD  rG  rJ  rL  rN  rP  rR  rV  rX  rZ  rF   r  rg  r  r   r  r  r  r{  r   r  r  r  r"  r  r  r  r_  r  r  rA  rS  ro  r&  r<  AddCustomJsonFieldMappingAddCustomJsonEnumMappingrr  r   r    r!   <module>r     s   ' < % ( )&)++ )&X*@9,, *@Z"Y&& "HI-- H *Y.. *K)"3"3 K 1	)) 14.9!2!2 .9bR	)) R2Z** Z8U*Y U*p)"" )&/i// / (Y&&  (F6** 69!2!2 9 @)"3"3 @?	)) ?"/** /"?i// ?(T"i T"n'9,, '7)++ 7(K** K>&	!! &0I%% +Y&& +""*I%% "*J/Y&& /,,)## ,$<i// <0!C9$$ !CH68!2!2 68r*** *4*	)) *:589#4#4 58p<9,, <0&Y.. &4-I-- 4-nD9#4#4 D+)"3"3 +*%'Y.. %'P'i&7&7 '(1Y%6%6 1 ,0I-- ,0^19,, 1&)## &DlPy(( lP^e5y   e5PK** K4	"9$$ 	"(Y.. (,#Y # 	;I%% 	;(>	)) (>VA)++ A,y(( I 8y(( 84#+Y&& #+LSi'' S#AY.. #AL!/i// !/HyB	)) yBx!#9 !#H+I +"()9,, ()VY&& 7Y.. 7$:)++ :Vy(( V*'i'' 'Si'' SI-- .)## .-BI%% -B`'B9,, 'BTu)y   u)p	m=Y&& m=`8y00 8>'	 1 1 '"T)	)) T)n&y00 &O)

 O3Py   3PlC9$$ C8II%% I!@Y !@HE9#4#4 E&
+)"3"3 
++)++ +EY%6%6 E 
+	 1 1 
+
+I-- 
+E9+<+< E"+)"3"3 +Ji.?.? J*8Y%6%6 8$8I-- 8"8Y.. 8$
;	)) 
;
A9,, 
A
CI-- 
C0#i'' 0#ft'Y t'nE9$$ EQi'' QC)

 C"=y   =2)## 2$])++ ]79$$ 7"Fy'8'8 F".y   .B	CI%% 	Ci8	!! i8X'	)) '"<y'8'8 <JMy(( JMZ	+	!! 	+,** ,>C,9,, C,L1y(( 1,qAI-- qAhA9,, A:	9	)) 	9,9,, ,6AY&& AyIy   yIxIGY IGX""" "2	H** 	H".9$$ ".J@	!! @!'"" !'H
A"" 
A.%y   .%bHB)## HBV)G	!! )GXKY.. K&(7)## (7V"7y(( "7J0,Y&& 0,f38i&7&7 38l0Ci// 0CfRY.. R.C)## C4$6	!! $6NA	)) A231Y&& 31l*i'' */'9 /'d'y   '$F"i F"R
/)++ 
/1<)++ 1<h-** -*39J9J *3Z3)2C2C 3+)2C2C +,1y/@/@ 13	0A0A 3&1I<M<M 11I<M<M 119J9J 13):K:K 30Y1B1B Y1	8I8I 139J9J 3$1YEVEV 11YEVEV 11)BSBS 139CTCT 30M):K:K M =3):K:K =3@31B1B 3C393D3D C3L193D3D 159J9J 51	0A0A 1(31B1B (3V1Y=N=N 11Y=N=N 11):K:K 139;L;L 30()2C2C (2I9J9J IUy?P?P U3I,=,= 3,3I<M<M ,3^5Y=N=N 53IDUDU 3$1IDUDU 15)J[J[ 5 1ARAR 13)BSBS 3&(9CTCT (0I)J[J[ I UPYPaPa U"3Y5F5F 33	@Q@Q 3"UiN_N_ U"59;L;L 55Y5F5F 559;L;L 51)2C2C 1(7y7H7H (7V393D3D 3"1y?P?P 11y?P?P 11I<M<M 13Y=N=N 30(I4E4E ($Oi6G6G O 19CTCT 1
3i>O>O 
3
5)BSBS 
5
4ARAR 
44yGXGX 4
4Y=N=N 
4
5Y=N=N 
51Y=N=N 14iFWFW 4
4ARAR 
44)J[J[ 41):K:K 1'9;L;L '.
4YEVEV 
4
4IDUDU 
4	49;L;L 	44y?P?P 4	4IDUDU 	4I9;L;L IUARAR U
S	8I8I 
S1I,=,= 15)2C2C 51):): 113YEVEV 13h3i>O>O 31i>O>O 1"	19;L;L 	13I<M<M 301	HYHY 11	HYHY 11YEVEV 13iFWFW 32_Y=N=N _"3)*;*; 3B1)*;*; 11i6G6G 11i6G6G 1193D3D 13I4E4E 30M9+<+< M I)2C2C IU	8I8I U+7i// +7\#)## #(u(y   u(p<.i// <.~b!	!! b!J0%Y 0%f="" =	8	 1 1 	88!2!2 8+)## +4C5** C5L>)++ >(BK9 BKJ(	 1 1 (@*7y00 *7Z?Y.. ?(I-- (D9#4#4 D+)"3"3 +,%'Y.. %'P'i&7&7 '&EY%6%6 E"3I-- 3"(I-- ($.H	)) .HbLI LD 	 " "Z4  ! !114>  ! !114>  " "02SUvx  " "02OQnp  " "02PRprr    