
    i                    	   d Z ddlmZ ddlmZ ddlmZ ddlmZ dZ	 G d dej                        Z G d	 d
ej                        Z G d dej                        Z G d dej                        Z G d dej                        Z G d dej                        Z G d dej                        Z G d dej                        Z G d dej                        Z G d dej                        Z G d dej                        Z G d dej                        Z G d d ej                        Z G d! d"ej                        Z G d# d$ej                        Z G d% d&ej                        Z G d' d(ej                        Z G d) d*ej                        Z G d+ d,ej                        Z G d- d.ej                        Z G d/ d0ej                        Z G d1 d2ej                        Z  G d3 d4ej                        Z! G d5 d6ej                        Z" G d7 d8ej                        Z# G d9 d:ej                        Z$ G d; d<ej                        Z% G d= d>ej                        Z& G d? d@ej                        Z' G dA dBej                        Z( G dC dDej                        Z) G dE dFej                        Z* G dG dHej                        Z+ G dI dJej                        Z, G dK dLej                        Z- G dM dNej                        Z. G dO dPej                        Z/ G dQ dRej                        Z0 G dS dTej                        Z1 G dU dVej                        Z2 G dW dXej                        Z3 G dY dZej                        Z4 G d[ d\ej                        Z5 G d] d^ej                        Z6 G d_ d`ej                        Z7 G da dbej                        Z8 G dc ddej                        Z9 G de dfej                        Z: G dg dhej                        Z; G di djej                        Z< G dk dlej                        Z= G dm dnej                        Z> ej~                  e:dodp        ej                  e:j                  dqdr        ej                  e:j                  dsdt        ej~                  edudv       yw)xzmGenerated message classes for geminicloudassist version v1alpha.

The AI-powered assistant for Google Cloud.
    )absolute_import)messages)encoding)extra_typesgeminicloudassistc                   ~    e Zd ZdZ ej
                  dd      Z ej                  d      Z ej                  d      Z	y)AbsentObservationa  An identifier of an observation that is needed. Typically a parameter
  but extensible to other cases.

  Fields:
    generalMissingObservation: Optional. A missing observation that the user
      could supply that is not a runbook parameter.
    param: Optional. A runbook parameter.
    pendingObservation: Optional. An observation that is not yet created that
      an observer should create by running. This might prompt the system to
      execute a runbook.
  GeneralAbsentObservation         N)
__name__
__module____qualname____doc__	_messagesMessageFieldgeneralMissingObservationStringFieldparampendingObservation     ilib/googlecloudsdk/generated_clients/apis/geminicloudassist/v1alpha/geminicloudassist_v1alpha_messages.pyr	   r	      sE    
 5i445OQRS
)


"%,y,,Q/r   r	   c                   ^    e Zd ZdZ ej
                  ddd      Z ej                  d      Zy)AuditConfiga  Specifies the audit configuration for a service. The configuration
  determines which permission types are logged, and what identities, if any,
  are exempted from logging. An AuditConfig must have one or more
  AuditLogConfigs. If there are AuditConfigs for both `allServices` and a
  specific service, the union of the two AuditConfigs is used for that
  service: the log_types specified in each AuditConfig are enabled, and the
  exempted_members in each AuditLogConfig are exempted. Example Policy with
  multiple AuditConfigs: { "audit_configs": [ { "service": "allServices",
  "audit_log_configs": [ { "log_type": "DATA_READ", "exempted_members": [
  "user:jose@example.com" ] }, { "log_type": "DATA_WRITE" }, { "log_type":
  "ADMIN_READ" } ] }, { "service": "sampleservice.googleapis.com",
  "audit_log_configs": [ { "log_type": "DATA_READ" }, { "log_type":
  "DATA_WRITE", "exempted_members": [ "user:aliya@example.com" ] } ] } ] } For
  sampleservice, this policy enables DATA_READ, DATA_WRITE and ADMIN_READ
  logging. It also exempts `jose@example.com` from DATA_READ logging, and
  `aliya@example.com` from DATA_WRITE logging.

  Fields:
    auditLogConfigs: The configuration for logging of each type of permission.
    service: Specifies a service that will be enabled for audit logging. For
      example, `storage.googleapis.com`, `cloudsql.googleapis.com`.
      `allServices` is a special value that covers all services.
  AuditLogConfigr   Trepeatedr   N)	r   r   r   r   r   r   auditLogConfigsr   servicer   r   r   r   r   #   s2    0 +I**+;QN/!I!!!$'r   r   c                       e Zd ZdZ G d dej
                        Z ej                  dd      Z ej                  dd      Z
y)	r   ah  Provides the configuration for logging a type of permissions. Example: {
  "audit_log_configs": [ { "log_type": "DATA_READ", "exempted_members": [
  "user:jose@example.com" ] }, { "log_type": "DATA_WRITE" } ] } This enables
  'DATA_READ' and 'DATA_WRITE' logging, while exempting jose@example.com from
  DATA_READ logging.

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

  Fields:
    exemptedMembers: Specifies the identities that do not cause logging for
      this type of permission. Follows the same format of Binding.members.
    logType: The log type that this config enables.
  c                        e Zd ZdZdZdZdZdZy)%AuditLogConfig.LogTypeValueValuesEnuma.  The log type that this config enables.

    Values:
      LOG_TYPE_UNSPECIFIED: Default case. Should never be this.
      ADMIN_READ: Admin reads. Example: CloudIAM getIamPolicy
      DATA_WRITE: Data writes. Example: CloudSQL Users create
      DATA_READ: Data reads. Example: CloudSQL Users list
    r   r   r   r   N)r   r   r   r   LOG_TYPE_UNSPECIFIED
ADMIN_READ
DATA_WRITE	DATA_READr   r   r   LogTypeValueValuesEnumr$   P   s     JJIr   r)   r   Tr   r   N)r   r   r   r   r   Enumr)   r   exemptedMembers	EnumFieldlogTyper   r   r   r   r   @   sB    y~~  *I))!d;/I 8!<'r   r   c                       e Zd ZdZ ej
                  dd      Z ej                  dd      Z ej                  d      Z	y)	Bindinga  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   N)
r   r   r   r   r   r   	conditionr   membersroler   r   r   r/   r/   b   sE    Ob %i$$VQ/)!I!!!d3'			q	!$r   r/   c                       e Zd ZdZy)CancelOperationRequestz3The request message for Operations.CancelOperation.Nr   r   r   r   r   r   r   r5   r5      s    <r   r5   c                       e Zd ZdZ ej
                  dd      Z ej                  dd      Z ej
                  dd      Z	y	)
ClarificationNeededa  A clarification needed by the system.

  Fields:
    generalMissingObservation: Optional. A missing observation that is not a
      runbook parameter.
    parentObserverNames: Optional. The display names of the observers that
      asked for this clarification. The UI will group by these names.
    runbookParameter: Optional. The result of a clarification is an
      observation. A runbook parameter that the user needs to provide.
  r
   r   r   Tr   RunbookParameterr   N)
r   r   r   r   r   r   r   r   parentObserverNamesrunbookParameterr   r   r   r8   r8      sK    	 5i445OQRS-	--a$?+Y++,>Br   r8   c                       e Zd ZdZy)Emptya!  A generic empty message that you can re-use to avoid defining duplicated
  empty messages in your APIs. A typical example is to use it as the request
  or the response type of an API method. For instance: service Foo { rpc
  Bar(google.protobuf.Empty) returns (google.protobuf.Empty); }
  Nr6   r   r   r   r=   r=      s    r   r=   c                       e Zd ZdZ ej
                  d      Z ej
                  d      Z ej
                  d      Z ej
                  d      Z	y)r0   a  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      N)
r   r   r   r   r   r   description
expressionlocationtitler   r   r   r0   r0      sQ    : &	%%a(+$y$$Q'*"Y""1%(
)


"%r   r0   c                   8    e Zd ZdZ ej
                  dd      Zy),GeminicloudassistProjectsLocationsGetRequestznA GeminicloudassistProjectsLocationsGetRequest object.

  Fields:
    name: Resource name for the location.
  r   TrequiredNr   r   r   r   r   r   namer   r   r   rE   rE           
		q4	0$r   rE   c                       e Zd ZdZ ej
                  dd      Z ej                  d      Z ej                  dd      Z	 ej                  d      Z
y	)
=GeminicloudassistProjectsLocationsInvestigationsCreateRequesta;  A GeminicloudassistProjectsLocationsInvestigationsCreateRequest object.

  Fields:
    investigation: A Investigation resource to be passed as the request body.
    investigationId: Optional. ID to use for the investigation, which will
      become the final component of the investigation's resource name. This
      value should be 4-63 characters, and valid characters are /a-z-/. If not
      provided, the server will generate a unique ID for the investigation.
    parent: Required. Value for parent.
    requestId: Optional. An optional request ID to identify requests. Specify
      a unique request ID so that if you must retry your request, the server
      will know to ignore the request if it has already been completed. The
      server will guarantee that for at least 60 minutes since the first
      request. For example, consider a situation where you make an initial
      request and the request times out. If you make the request again with
      the same request ID, the server can check if original operation with the
      same request ID was received, and if so, will ignore the second request.
      This prevents clients from accidentally creating duplicate commitments.
      The request ID must be a valid UUID with the exception that zero UUID is
      not supported (00000000-0000-0000-0000-000000000000).
  Investigationr   r   r   TrF   r?   N)r   r   r   r   r   r   investigationr   investigationIdparent	requestIdr   r   r   rL   rL     sU    , ))((!<-)I))!,/ 9  T2&#i##A&)r   rL   c                   \    e Zd ZdZ ej
                  dd      Z ej
                  d      Zy)=GeminicloudassistProjectsLocationsInvestigationsDeleteRequesta  A GeminicloudassistProjectsLocationsInvestigationsDeleteRequest object.

  Fields:
    name: Required. Name of the resource
    requestId: Optional. An optional request ID to identify requests. Specify
      a unique request ID so that if you must retry your request, the server
      will know to ignore the request if it has already been completed. The
      server will guarantee that for at least 60 minutes after the first
      request. For example, consider a situation where you make an initial
      request and the request times out. If you make the request again with
      the same request ID, the server can check if original operation with the
      same request ID was received, and if so, will ignore the second request.
      This prevents clients from accidentally creating duplicate commitments.
      The request ID must be a valid UUID with the exception that zero UUID is
      not supported (00000000-0000-0000-0000-000000000000).
  r   TrF   r   Nr   r   r   r   r   r   rI   rQ   r   r   r   rS   rS   "  s/    " 
		q4	0$#i##A&)r   rS   c                       e Zd ZdZ ej
                  dej                  j                        Z ej                  dd      Z
y)CGeminicloudassistProjectsLocationsInvestigationsGetIamPolicyRequestau  A GeminicloudassistProjectsLocationsInvestigationsGetIamPolicyRequest
  object.

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

  Fields:
    name: Required. Name of the resource
  r   TrF   NrH   r   r   r   r_   r_   S  rJ   r   r_   c                       e Zd ZdZ ej
                  d      Z ej
                  d      Z ej                  dej                  j                        Z ej
                  d      Z ej
                  dd	      Zy
);GeminicloudassistProjectsLocationsInvestigationsListRequesta  A GeminicloudassistProjectsLocationsInvestigationsListRequest object.

  Fields:
    filter: Optional. Filtering results
    orderBy: Optional. Hint for how to order the results
    pageSize: Optional. Requested page size. Server may return fewer items
      than requested. If unspecified, server will pick an appropriate default.
    pageToken: Optional. A token identifying a page of results the server
      should return.
    parent: Required. Parent value for ListInvestigationsRequest
  r   r   r   rW   r?      TrF   N)r   r   r   r   r   r   filterorderByrY   rZ   r[   pageSize	pageTokenrP   r   r   r   ra   ra   ]  ss    
 !9  #&!I!!!$'#Y##Ay/@/@/F/FG(#i##A&) 9  T2&r   ra   c                       e Zd ZdZ ej
                  dd      Z ej                  dd      Z ej                  d      Z	 ej                  d      Z
y	)
<GeminicloudassistProjectsLocationsInvestigationsPatchRequesta  A GeminicloudassistProjectsLocationsInvestigationsPatchRequest object.

  Fields:
    investigation: A Investigation resource to be passed as the request body.
    name: Identifier. name of resource
    requestId: Optional. An optional request ID to identify requests. Specify
      a unique request ID so that if you must retry your request, the server
      will know to ignore the request if it has already been completed. The
      server will guarantee that for at least 60 minutes since the first
      request. For example, consider a situation where you make an initial
      request and the request times out. If you make the request again with
      the same request ID, the server can check if original operation with the
      same request ID was received, and if so, will ignore the second request.
      This prevents clients from accidentally creating duplicate commitments.
      The request ID must be a valid UUID with the exception that zero UUID is
      not supported (00000000-0000-0000-0000-000000000000).
    updateMask: Optional. Field mask is used to specify the fields to be
      overwritten in the Investigation resource by the update. The fields
      specified in the update_mask are relative to the resource, not the full
      request. A field will be overwritten if it is in the mask. If the user
      does not provide a mask then all fields present in the request will be
      overwritten.
  rM   r   r   TrF   r   r?   N)r   r   r   r   r   r   rN   r   rI   rQ   
updateMaskr   r   r   rh   rh   q  sU    0 ))((!<-			q4	0$#i##A&)$y$$Q'*r   rh   c                       e Zd ZdZ ej
                  dd      Z ej                  d      Z ej                  dd      Z	 ej                  d      Z
y	)
FGeminicloudassistProjectsLocationsInvestigationsRevisionsCreateRequesta  A GeminicloudassistProjectsLocationsInvestigationsRevisionsCreateRequest
  object.

  Fields:
    investigationRevision: A InvestigationRevision resource to be passed as
      the request body.
    investigationRevisionId: Optional. ID to use for the revision, which will
      become the final component of the revision's resource name. If not
      provided, the server will generate a unique ID for the revision.
    parent: Required. Parent investigation
    requestId: Optional. An optional request ID to identify requests. Specify
      a unique request ID so that if you must retry your request, the server
      will know to ignore the request if it has already been completed. The
      server will guarantee that for at least 60 minutes since the first
      request. For example, consider a situation where you make an initial
      request and the request times out. If you make the request again with
      the same request ID, the server can check if original operation with the
      same request ID was received, and if so, will ignore the second request.
      This prevents clients from accidentally creating duplicate commitments.
      The request ID must be a valid UUID with the exception that zero UUID is
      not supported (00000000-0000-0000-0000-000000000000).
  InvestigationRevisionr   r   r   TrF   r?   N)r   r   r   r   r   r   investigationRevisionr   investigationRevisionIdrP   rQ   r   r   r   rk   rk     sX    . 1)001H!L1I11!4 9  T2&#i##A&)r   rk   c                   \    e Zd ZdZ ej
                  dd      Z ej
                  d      Zy)FGeminicloudassistProjectsLocationsInvestigationsRevisionsDeleteRequesta  A GeminicloudassistProjectsLocationsInvestigationsRevisionsDeleteRequest
  object.

  Fields:
    name: Required. Name of the resource
    requestId: Optional. An optional request ID to identify requests. Specify
      a unique request ID so that if you must retry your request, the server
      will know to ignore the request if it has already been completed. The
      server will guarantee that for at least 60 minutes after the first
      request. For example, consider a situation where you make an initial
      request and the request times out. If you make the request again with
      the same request ID, the server can check if original operation with the
      same request ID was received, and if so, will ignore the second request.
      This prevents clients from accidentally creating duplicate commitments.
      The request ID must be a valid UUID with the exception that zero UUID is
      not supported (00000000-0000-0000-0000-000000000000).
  r   TrF   r   NrT   r   r   r   rp   rp     s/    $ 
		q4	0$#i##A&)r   rp   c                   8    e Zd ZdZ ej
                  dd      Zy)CGeminicloudassistProjectsLocationsInvestigationsRevisionsGetRequestzA GeminicloudassistProjectsLocationsInvestigationsRevisionsGetRequest
  object.

  Fields:
    name: Required. Name of the resource
  r   TrF   NrH   r   r   r   rr   rr     s     
		q4	0$r   rr   c                       e Zd ZdZ ej
                  dej                  j                        Z ej                  d      Z
 ej                  dd      Zy)	DGeminicloudassistProjectsLocationsInvestigationsRevisionsListRequesta  A GeminicloudassistProjectsLocationsInvestigationsRevisionsListRequest
  object.

  Fields:
    pageSize: Optional. Requested page size. Server may return fewer items
      than requested. If unspecified, server will pick an appropriate default.
    pageToken: Optional. A token identifying a page of results the server
      should return.
    parent: Required. Parent value for ListInvestigationRevisionsRequest
  r   rW   r   r   TrF   N)r   r   r   r   r   rY   rZ   r[   re   r   rf   rP   r   r   r   rt   rt     sO    	 $Y##Ay/@/@/F/FG(#i##A&) 9  T2&r   rt   c                       e Zd ZdZ ej
                  dd      Z ej                  dd      Z ej                  d      Z	 ej                  d      Z
y	)
EGeminicloudassistProjectsLocationsInvestigationsRevisionsPatchRequesta  A GeminicloudassistProjectsLocationsInvestigationsRevisionsPatchRequest
  object.

  Fields:
    investigationRevision: A InvestigationRevision resource to be passed as
      the request body.
    name: Identifier. name of resource
    requestId: Optional. An optional request ID to identify requests. Specify
      a unique request ID so that if you must retry your request, the server
      will know to ignore the request if it has already been completed. The
      server will guarantee that for at least 60 minutes since the first
      request. For example, consider a situation where you make an initial
      request and the request times out. If you make the request again with
      the same request ID, the server can check if original operation with the
      same request ID was received, and if so, will ignore the second request.
      This prevents clients from accidentally creating duplicate commitments.
      The request ID must be a valid UUID with the exception that zero UUID is
      not supported (00000000-0000-0000-0000-000000000000).
    updateMask: Optional. Field mask is used to specify the fields to be
      overwritten in the Investigation resource by the update. The fields
      specified in the update_mask are relative to the revision's snapshot,
      not the full request. A field will be overwritten if it is in the mask.
      If the user does not provide a mask then all fields present in the
      request will be overwritten.
  rl   r   r   TrF   r   r?   N)r   r   r   r   r   r   rm   r   rI   rQ   ri   r   r   r   rv   rv     sW    4 1)001H!L			q4	0$#i##A&)$y$$Q'*r   rv   c                   ^    e Zd ZdZ ej
                  dd      Z ej                  dd      Zy)CGeminicloudassistProjectsLocationsInvestigationsRevisionsRunRequesta  A GeminicloudassistProjectsLocationsInvestigationsRevisionsRunRequest
  object.

  Fields:
    name: Required. Run the investigation revision. The revision to run,
      format: projects/{project}/locations/global/investigations/{investigatio
      n}/revisions/{revision}
    runInvestigationRevisionRequest: A RunInvestigationRevisionRequest
      resource to be passed as the request body.
  r   TrF   RunInvestigationRevisionRequestr   N)	r   r   r   r   r   r   rI   r   runInvestigationRevisionRequestr   r   r   rx   rx     s4    	 
		q4	0$$:I$:$:;\^_$`!r   rx   c                   ^    e Zd ZdZ ej
                  dd      Z ej                  dd      Zy)CGeminicloudassistProjectsLocationsInvestigationsSetIamPolicyRequesta  A GeminicloudassistProjectsLocationsInvestigationsSetIamPolicyRequest
  object.

  Fields:
    resource: REQUIRED: The resource for which the policy is being specified.
      See [Resource
      names](https://cloud.google.com/apis/design/resource_names) for the
      appropriate value for this field.
    setIamPolicyRequest: A SetIamPolicyRequest resource to be passed as the
      request body.
  r   TrF   SetIamPolicyRequestr   N)	r   r   r   r   r   r   r]   r   setIamPolicyRequestr   r   r   r|   r|     s3    
 #Y""1t4(.	../DaHr   r|   c                   ^    e Zd ZdZ ej
                  dd      Z ej                  dd      Zy)IGeminicloudassistProjectsLocationsInvestigationsTestIamPermissionsRequesta  A
  GeminicloudassistProjectsLocationsInvestigationsTestIamPermissionsRequest
  object.

  Fields:
    resource: REQUIRED: The resource for which the policy detail is being
      requested. See [Resource
      names](https://cloud.google.com/apis/design/resource_names) for the
      appropriate value for this field.
    testIamPermissionsRequest: A TestIamPermissionsRequest resource to be
      passed as the request body.
  r   TrF   TestIamPermissionsRequestr   N)	r   r   r   r   r   r   r]   r   testIamPermissionsRequestr   r   r   r   r   #  s4     #Y""1t4(4i445PRSTr   r   c                       e Zd ZdZ ej
                  dd      Z ej
                  d      Z ej
                  dd      Z ej                  dej                  j                  	      Z ej
                  d
      Zy)-GeminicloudassistProjectsLocationsListRequesta   A GeminicloudassistProjectsLocationsListRequest object.

  Fields:
    extraLocationTypes: Optional. A list of extra location types that should
      be used as conditions for controlling the visibility of the locations.
    filter: A filter to narrow down results to a preferred subset. The
      filtering language accepts strings like `"displayName=tokyo"`, and is
      documented in more detail in [AIP-160](https://google.aip.dev/160).
    name: The resource that owns the locations collection, if applicable.
    pageSize: The maximum number of results to return. If not set, the service
      selects a default.
    pageToken: A page token received from the `next_page_token` field in the
      response. Send that page token to receive the subsequent page.
  r   Tr   r   r   rF   r?   rW   rb   N)r   r   r   r   r   r   extraLocationTypesrc   rI   rY   rZ   r[   re   rf   r   r   r   r   r   5  sv     -y,,Q> 9  #&			q4	0$#Y##Ay/@/@/F/FG(#i##A&)r   r   c                   ^    e Zd ZdZ ej
                  dd      Z ej                  dd      Zy)9GeminicloudassistProjectsLocationsOperationsCancelRequestzA GeminicloudassistProjectsLocationsOperationsCancelRequest object.

  Fields:
    cancelOperationRequest: A CancelOperationRequest resource to be passed as
      the request body.
    name: The name of the operation resource to be cancelled.
  r5   r   r   TrF   N)	r   r   r   r   r   r   cancelOperationRequestr   rI   r   r   r   r   r   L  s3     29112JAN			q4	0$r   r   c                   8    e Zd ZdZ ej
                  dd      Zy)9GeminicloudassistProjectsLocationsOperationsDeleteRequestzA GeminicloudassistProjectsLocationsOperationsDeleteRequest object.

  Fields:
    name: The name of the operation resource to be deleted.
  r   TrF   NrH   r   r   r   r   r   Y  rJ   r   r   c                   8    e Zd ZdZ ej
                  dd      Zy)6GeminicloudassistProjectsLocationsOperationsGetRequestz|A GeminicloudassistProjectsLocationsOperationsGetRequest object.

  Fields:
    name: The name of the operation resource.
  r   TrF   NrH   r   r   r   r   r   c  rJ   r   r   c                       e Zd ZdZ ej
                  d      Z ej
                  dd      Z ej                  dej                  j                        Z ej
                  d      Zy	)
7GeminicloudassistProjectsLocationsOperationsListRequesta  A GeminicloudassistProjectsLocationsOperationsListRequest 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.
  r   r   TrF   r   rW   r?   N)r   r   r   r   r   r   rc   rI   rY   rZ   r[   re   rf   r   r   r   r   r   m  sa     !9  #&			q4	0$#Y##Ay/@/@/F/FG(#i##A&)r   r   c                   |    e Zd ZdZ ej
                  d      Z ej
                  d      Z ej
                  d      Zy)r
   a  An absent observation that is not a runbook parameter.

  Fields:
    id: Optional. The ID of the missing observation.
    title: Optional. The title to display in the UI
    validationRegex: Optional. The regex that the answer must match. Must
      conform to JavaScript's regular expression string pattern syntax. See
      https://developer.mozilla.org/en-
      US/docs/Web/JavaScript/Reference/Global_Objects/RegExp/RegExp#syntax
  r   r   r   N)	r   r   r   r   r   r   idrC   validationRegexr   r   r   r
   r
   }  s?    	 yQ"
)


"%)I))!,/r   r
   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)Intervalak  Represents a time interval, encoded as a Timestamp start (inclusive) and
  a Timestamp end (exclusive). The start must be less than or equal to the
  end. When the start equals the end, the interval is empty (matches no time).
  When both start and end are unspecified, the interval matches any time.

  Fields:
    endTime: Optional. Exclusive end of the interval. If specified, a
      Timestamp matching this interval will have to be before the end.
    startTime: Optional. Inclusive start of the interval. If specified, a
      Timestamp matching this interval will have to be the same or after the
      start.
  r   r   Nr   r   r   r   r   r   endTime	startTimer   r   r   r   r     s-     "I!!!$'#i##A&)r   r   c                   0   e Zd ZdZ G d dej
                        Z ej                  d       G d dej                               Z
 ej                  d       G d dej                               Z ej                  d       G d	 d
ej                               Z ej                  d       G d dej                               Z ej                  dd      Z ej                  dd      Z ej"                  d      Z ej&                  dej(                  j*                        Z ej                  dd      Z ej0                  dd      Z ej                  dd      Z ej"                  d      Z ej                  d
d      Z ej                  dd      Z ej"                  d      Z ej"                  d      Z ej&                  dej(                  j*                        Z  ej"                  d      Z! ej"                  d      Z" ej"                  d      Z#y )!rM   ao  Message describing Investigation object Next Id: 24

  Enums:
    ExecutionStateValueValuesEnum: Output only. [Output only] The execution
      state of this investigation.

  Messages:
    ClarificationsNeededValue: Optional. Questions that the system needs to
      ask the user. The results will be passed back by the UI as new
      Observations. The ID for those observations will be the key of the entry
      in the clarifications_needed map.
    LabelsValue: Optional. Labels as key value pairs
    ObservationsValue: Optional. A map from observation ID to the observation.
      This is a map so that we can cleanly overwrite old observations with the
      version from the latest revision. See Observation for guidance on
      choosing IDs.
    ObserverStatusesValue: Optional. Plural version of above. Code will
      transition to this over time.

  Fields:
    annotations: Optional. Annotations on the investigation. Unlike labels,
      these may carry semantic meaning in running the investigation, and will
      not be read by other systems such as billing.
    clarificationsNeeded: Optional. Questions that the system needs to ask the
      user. The results will be passed back by the UI as new Observations. The
      ID for those observations will be the key of the entry in the
      clarifications_needed map.
    createTime: Output only. [Output only] Create time stamp
    dataVersion: Optional. The data model version of this Investigation.
      Should be either 1 or 2. Treat 0 as 1. If 1, use V1 Investigation data
      model. If 2, use the Investigation Observation data model.
    error: Output only. [Output only] If the investigation execution state is
      FAILED, this field will contain the error message.
    executionState: Output only. [Output only] The execution state of this
      investigation.
    labels: Optional. Labels as key value pairs
    name: Identifier. name of resource
    observations: Optional. A map from observation ID to the observation. This
      is a map so that we can cleanly overwrite old observations with the
      version from the latest revision. See Observation for guidance on
      choosing IDs.
    observerStatuses: Optional. Plural version of above. Code will transition
      to this over time.
    operation: Output only. The Run operation most recently performed on the
      investigation.
    revision: Output only. [Output only] Current revision of the investigation
    revisionIndex: Output only. [Output only] Index of the current revision of
      the investigation. 1-based.
    revisionPredecessor: Optional. The name of the revision that was this
      revision's predecessor. The UI, for example, will set this to the
      existing revision when when a new revision is created due to an edit.
    title: Required. Human-readable display title for the investigation.
    updateTime: Output only. [Output only] Update time stamp
  c                   $    e Zd ZdZdZdZdZdZdZy)+Investigation.ExecutionStateValueValuesEnuma  Output only. [Output only] The execution state of this investigation.

    Values:
      INVESTIGATION_EXECUTION_STATE_UNSPECIFIED: Default value. This value is
        unused.
      INVESTIGATION_EXECUTION_STATE_RUNNING: The investigation is being
        executed.
      INVESTIGATION_EXECUTION_STATE_MODIFIED: The investigation has not yet
        been executed since the symptom was last updated.
      INVESTIGATION_EXECUTION_STATE_FAILED: The investigation execution has
        completed, but the execution has failed.
      INVESTIGATION_EXECUTION_STATE_COMPLETED: All execution tasks have
        completed and the investigation is at rest.
    r   r   r   r   r?   N)	r   r   r   r   )INVESTIGATION_EXECUTION_STATE_UNSPECIFIED%INVESTIGATION_EXECUTION_STATE_RUNNING&INVESTIGATION_EXECUTION_STATE_MODIFIED$INVESTIGATION_EXECUTION_STATE_FAILED'INVESTIGATION_EXECUTION_STATE_COMPLETEDr   r   r   ExecutionStateValueValuesEnumr     s'     12-,-)-.*+,(./+r   r   additionalPropertiesc                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)'Investigation.ClarificationsNeededValuea  Optional. Questions that the system needs to ask the user. The results
    will be passed back by the UI as new Observations. The ID for those
    observations will be the key of the entry in the clarifications_needed
    map.

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

    Fields:
      additionalProperties: Additional properties of type
        ClarificationsNeededValue
    c                   Z    e Zd ZdZ ej
                  d      Z ej                  dd      Zy):Investigation.ClarificationsNeededValue.AdditionalPropertyzAn additional property for a ClarificationsNeededValue object.

      Fields:
        key: Name of the additional property.
        value: A ClarificationNeeded attribute.
      r   r8   r   N	r   r   r   r   r   r   keyr   valuer   r   r   AdditionalPropertyr     s0    
 "I!!!$c$i$$%:A>er   r   r   Tr   N	r   r   r   r   r   Messager   r   r   r   r   r   ClarificationsNeededValuer     s4    	?Y.. 	? 29112FTXYr   r   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)Investigation.LabelsValueOptional. Labels as key value pairs

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

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

      Fields:
        key: Name of the additional property.
        value: A string attribute.
      r   r   Nr   r   r   r   r   r   r   r   r   r   r   r   r     -    
 "I!!!$c#i##A&er   r   r   Tr   Nr   r   r   r   LabelsValuer   
  4    	'Y.. 	' 29112FTXYr   r   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)Investigation.ObservationsValuea  Optional. A map from observation ID to the observation. This is a map
    so that we can cleanly overwrite old observations with the version from
    the latest revision. See Observation for guidance on choosing IDs.

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

    Fields:
      additionalProperties: Additional properties of type ObservationsValue
    c                   Z    e Zd ZdZ ej
                  d      Z ej                  dd      Zy)2Investigation.ObservationsValue.AdditionalPropertyzAn additional property for a ObservationsValue object.

      Fields:
        key: Name of the additional property.
        value: A Observation attribute.
      r   Observationr   Nr   r   r   r   r   r   0  s/    
 "I!!!$c$i$$]A6er   r   r   Tr   Nr   r   r   r   ObservationsValuer   "  s4    
	7Y.. 	7 29112FTXYr   r   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)#Investigation.ObserverStatusesValuea$  Optional. Plural version of above. Code will transition to this over
    time.

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

    Fields:
      additionalProperties: Additional properties of type
        ObserverStatusesValue
    c                   Z    e Zd ZdZ ej
                  d      Z ej                  dd      Zy)6Investigation.ObserverStatusesValue.AdditionalPropertyzAn additional property for a ObserverStatusesValue object.

      Fields:
        key: Name of the additional property.
        value: A ObserverStatus attribute.
      r   ObserverStatusr   Nr   r   r   r   r   r   K  s0    
 "I!!!$c$i$$%5q9er   r   r   Tr   Nr   r   r   r   ObserverStatusesValuer   =  s4    
	:Y.. 	: 29112FTXYr   r   InvestigationAnnotationsr   r   r   r?   rW   Statusrb            	   
                     N)$r   r   r   r   r   r*   r   r   MapUnrecognizedFieldsr   r   r   r   r   r   annotationsclarificationsNeededr   
createTimerY   rZ   r[   dataVersionerrorr,   executionStatelabelsrI   observationsobserverStatuses	operationrevisionrevisionIndexrevisionPredecessorrC   
updateTimer   r   r   rM   rM     s4   5n0inn 0* "8!!"89Z)"3"3 Z :Z8 "8!!"89ZI%% Z :Z. "8!!"89Z)++ Z :Z4 "8!!"89Zi// Z :Z4 '	&&'A1E+///0KQO$y$$Q'*&	&&q)2C2C2I2IJ+
 )
 
 1
-%&9&&'FJ.!9!!-3&			q	!$'''(;Q?,+Y++,CRH#i##B')"Y""2&(()((Y5F5F5L5LM--	--b1
)


#%$y$$R(*r   rM   c                   |   e Zd ZdZ ej
                  d       G d dej                               Z ej
                  d       G d dej                               Z	 ej
                  d       G d dej                               Z
 ej                  dd	      Z ej                  dd
      Z ej                  dd      Z ej                  d      Z ej                  d      Z ej$                  d      Z ej                  dd      Z ej$                  d      Z ej                  d      Z ej                  d      Zy)r   a	  Additional user-defined annotations on an Investigation. There are some
  pre-defined ones, and a map for new applications to add their own.

  Messages:
    ComponentVersionsValue: Output only. Map of component key to version.
      Filled in by the run process. The key is unique to a "component",
      broadly defined. A component might be the TAF framework, Titan, a GCA
      tool, etc. The version is a string that is unique to a particular
      release of the component, e.g., a build label.
    ExtrasMapValue: Optional. Additional annotations required by applications.
      These will not be redacted and should NOT contain any CCC/PII.
    FeatureFlagsValue: Output only. Map of feature flag names to their
      (string-serialized) values. Filled in by, and at the very start of, the
      run process. Treat as immutable for the subsequent life of an
      investigation run.

  Fields:
    componentVersions: Output only. Map of component key to version. Filled in
      by the run process. The key is unique to a "component", broadly defined.
      A component might be the TAF framework, Titan, a GCA tool, etc. The
      version is a string that is unique to a particular release of the
      component, e.g., a build label.
    extrasMap: Optional. Additional annotations required by applications.
      These will not be redacted and should NOT contain any CCC/PII.
    featureFlags: Output only. Map of feature flag names to their (string-
      serialized) values. Filled in by, and at the very start of, the run
      process. Treat as immutable for the subsequent life of an investigation
      run.
    followUp: Output only. Follow-up is required to continue the
      investigation. Generally set to true by the troubleshooter and false
      when the questions have been answered.
    newlyCreated: Optional. This investigation is been newly created and
      hasn't been saved by the user yet. Set to true when an Investigation is
      created by an application (like Chat) and false when the user requests
      action via the UI.
    pagePath: Optional. Page path field set by the UI.
    revisionLastRunInterval: Output only. Start/end time when the revision was
      last run.
    supportCase: Optional. The support case ID associated with the
      investigation.
    uiHidden: Optional. Whether the UI should hide this investigation from its
      list.
    uiReadOnly: Optional. Whether the UI should disable editing of this
      investigation.
  r   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)/InvestigationAnnotations.ComponentVersionsValuea  Output only. Map of component key to version. Filled in by the run
    process. The key is unique to a "component", broadly defined. A component
    might be the TAF framework, Titan, a GCA tool, etc. The version is a
    string that is unique to a particular release of the component, e.g., a
    build label.

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

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

      Fields:
        key: Name of the additional property.
        value: A string attribute.
      r   r   Nr   r   r   r   r   r     r   r   r   r   Tr   Nr   r   r   r   ComponentVersionsValuer     s4    	'Y.. 	' 29112FTXYr   r   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)'InvestigationAnnotations.ExtrasMapValuea5  Optional. Additional annotations required by applications. These will
    not be redacted and should NOT contain any CCC/PII.

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

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

      Fields:
        key: Name of the additional property.
        value: A string attribute.
      r   r   Nr   r   r   r   r   r     r   r   r   r   Tr   Nr   r   r   r   ExtrasMapValuer     4    	'Y.. 	' 29112FTXYr   r   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)*InvestigationAnnotations.FeatureFlagsValuea  Output only. Map of feature flag names to their (string-serialized)
    values. Filled in by, and at the very start of, the run process. Treat as
    immutable for the subsequent life of an investigation run.

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

    Fields:
      additionalProperties: Additional properties of type FeatureFlagsValue
    c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)=InvestigationAnnotations.FeatureFlagsValue.AdditionalPropertyzAn additional property for a FeatureFlagsValue object.

      Fields:
        key: Name of the additional property.
        value: A string attribute.
      r   r   Nr   r   r   r   r   r     r   r   r   r   Tr   Nr   r   r   r   FeatureFlagsValuer     4    
	'Y.. 	' 29112FTXYr   r   r   r   r   r?   rb   r   r   r   r   r   r   N)r   r   r   r   r   r   r   r   r   r   r   r   componentVersions	extrasMapfeatureFlagsBooleanFieldfollowUpnewlyCreatedr   pagePathrevisionLastRunIntervalsupportCaseuiHidden
uiReadOnlyr   r   r   r   r   j  sa   ,\ "8!!"89Zy00 Z :Z: "8!!"89Zy(( Z :Z0 "8!!"89Z)++ Z :Z4 -i,,-EqI$i$$%5q9)'''(;Q?,#Y##A&('''*,"Y""1%(2I22:qA%	%%a(+#Y##A&(%y%%b)*r   r   c                   H   e Zd ZdZ ej
                  d       G d dej                               Z ej                  d      Z
 ej                  dej                  j                        Z ej                  dd      Z ej                  d	      Z ej                  d
d      Zy)rl   a  Message describing a revision of an Investigation

  Messages:
    LabelsValue: Optional. Labels as key value pairs

  Fields:
    createTime: Output only. [Output only] Create time stamp
    index: Output only. Revision index number, in order of creation.
    labels: Optional. Labels as key value pairs
    name: Identifier. name of resource
    snapshot: Optional. [Output only] Snapshot of the investigation contents
      at this revision
  r   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)!InvestigationRevision.LabelsValuer   c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)4InvestigationRevision.LabelsValue.AdditionalPropertyr   r   r   Nr   r   r   r   r   r     r   r   r   r   Tr   Nr   r   r   r   r   r     r   r   r   r   r   rW   r   r?   rM   rb   N)r   r   r   r   r   r   r   r   r   r   r   rY   rZ   r[   indexr   r   rI   snapshotr   r   r   rl   rl     s     "8!!"89ZI%% Z :Z. %y$$Q'*
 )
 
 I,=,=,C,C
D%!9!!-3&			q	!$#Y##OQ7(r   rl   c                       e Zd ZdZ ej
                  d       G d dej                               Z ej                  dd      Z
y)InvestigationRunParametersa:  Represents user parameters for running an investigation.

  Messages:
    AccessTokensValue: Optional. If populated, map of project to access token
      for TSE-triggered investigations.

  Fields:
    accessTokens: Optional. If populated, map of project to access token for
      TSE-triggered investigations.
  r   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy),InvestigationRunParameters.AccessTokensValuea#  Optional. If populated, map of project to access token for TSE-
    triggered investigations.

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

    Fields:
      additionalProperties: Additional properties of type AccessTokensValue
    c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)?InvestigationRunParameters.AccessTokensValue.AdditionalPropertyzAn additional property for a AccessTokensValue object.

      Fields:
        key: Name of the additional property.
        value: A string attribute.
      r   r   Nr   r   r   r   r   r  >  r   r   r   r   Tr   Nr   r   r   r   AccessTokensValuer  1  s4    		'Y.. 	' 29112FTXYr   r  r   N)r   r   r   r   r   r   r   r   r  r   accessTokensr   r   r   r  r  %  sP    	 "8!!"89Z)++ Z :Z2 (''(;Q?,r   r  c                       e Zd ZdZ ej
                  d      Z ej                  ddd      Z ej
                  dd      Z	y)	"ListInvestigationRevisionsResponsea"  Message for response to listing revisions of a given Investigation

  Fields:
    nextPageToken: A token identifying a page of results the server should
      return.
    revisions: The list of Investigation revisions
    unreachable: Unordered list. Locations that could not be reached.
  r   rl   r   Tr   r   N)
r   r   r   r   r   r   nextPageTokenr   	revisionsunreachabler   r   r   r  r  N  sF     ()''*-$i$$%<a$O)%	%%a$7+r   r  c                       e Zd ZdZ ej
                  ddd      Z ej                  d      Z ej                  dd      Z	y)	ListInvestigationsResponsea	  Message for response to listing Investigations

  Fields:
    investigations: The list of Investigation
    nextPageToken: A token identifying a page of results the server should
      return.
    unreachable: Unordered list. Locations that could not be reached.
  rM   r   Tr   r   r   N)
r   r   r   r   r   r   investigationsr   r  r  r   r   r   r  r  ]  sE     *9))/1tL.')''*-%	%%a$7+r   r  c                   ^    e Zd ZdZ ej
                  ddd      Z ej                  d      Zy)ListLocationsResponsezThe response message for Locations.ListLocations.

  Fields:
    locations: A list of locations that matches the specified filter in the
      request.
    nextPageToken: The standard List next-page token.
  Locationr   Tr   r   N)	r   r   r   r   r   r   	locationsr   r  r   r   r   r  r  l  s1     %i$$ZTB)')''*-r   r  c                   ^    e Zd ZdZ ej
                  d      Z ej                  ddd      Zy)ListOperationsResponsezThe 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.
  r   	Operationr   Tr   N)	r   r   r   r   r   r   r  r   
operationsr   r   r   r  r  y  s1     ()''*-%y%%k1tD*r   r  c                   p   e Zd ZdZ ej
                  d       G d dej                               Z ej
                  d       G d dej                               Z	 ej                  d      Z ej                  dd      Z ej                  d	      Z ej                  dd
      Z ej                  d      Zy)r  ao  A resource that represents a Google Cloud location.

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

  Fields:
    displayName: The friendly name for this location, typically a nearby city
      name. For example, "Tokyo".
    labels: Cross-service attributes for the location. For example
      {"cloud.googleapis.com/region": "us-east1"}
    locationId: The canonical id for this location. For example: `"us-east1"`.
    metadata: Service-specific metadata. For example the available capacity at
      the given location.
    name: Resource name for the location, which may vary between
      implementations. For example: `"projects/example-project/locations/us-
      east1"`
  r   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)Location.LabelsValuea  Cross-service attributes for the location. For example
    {"cloud.googleapis.com/region": "us-east1"}

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

    Fields:
      additionalProperties: Additional properties of type LabelsValue
    c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)'Location.LabelsValue.AdditionalPropertyr   r   r   Nr   r   r   r   r   r    r   r   r   r   Tr   Nr   r   r   r   r   r    r   r   r   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)Location.MetadataValuea(  Service-specific metadata. For example the available capacity at the
    given location.

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

    Fields:
      additionalProperties: Properties of the object. Contains field @type
        with type URL.
    c                   Z    e Zd ZdZ ej
                  d      Z ej                  dd      Zy))Location.MetadataValue.AdditionalPropertyAn additional property for a MetadataValue object.

      Fields:
        key: Name of the additional property.
        value: A extra_types.JsonValue attribute.
      r   extra_types.JsonValuer   Nr   r   r   r   r   r"    0    
 "I!!!$c$i$$%<a@er   r   r   Tr   Nr   r   r   r   MetadataValuer     6    		AY.. 	A 29112FTXYr   r&  r   r   r   r?   rb   N)r   r   r   r   r   r   r   r   r   r&  r   displayNamer   r   
locationIdmetadatarI   r   r   r   r  r    s    * "8!!"89ZI%% Z :Z0 "8!!"89Zi'' Z :Z2 &	%%a(+!9!!-3&$y$$Q'*#Y##OQ7(			q	!$r   r  c                      e Zd ZdZ G d dej
                        Z G d dej
                        Z G d dej
                        Z G d d	ej
                        Z	 e
j                  d
       G d dej                               Z e
j                  d
       G d dej                               Z e
j                  d
       G d dej                               Z ej                   dd      Z ej$                  dd      Z ej$                  dd      Z ej                   d      Z ej$                  dd      Z ej.                  dd      Z ej.                  dd      Z ej4                  d      Z ej$                  ddd      Z ej.                  dd      Z ej                   d      Z ej.                  d	d      Z ej                   d d      Z  ejB                  d!ejD                  jF                  "      Z$ ej                   d#      Z% ej$                  d$d%d      Z& ej$                  d&d'd      Z' ej                   d(      Z(y))*r   a  An observation is the basic unit of interchange between user and system,
  or between different components of the system. It is the element that has a
  relevance. They should therefore be relatively small; if you expect users to
  react to "part" of an observation, it should be broken up into smaller
  observations. A particular runbook run, a particular user parameter input, a
  particular interesting log entry might all be separate observations. This
  means there might be dozens or hundreds in an investigation. Next Id: 26

  Enums:
    ObservationCompletionStateValueValuesEnum: Optional. An
      ObservationCompletionState represents whether the emitted observation is
      fully formed and should be shown the to the user. This is intended to
      allow hiding observations that are in an intermediate state.
    ObservationTypeValueValuesEnum: Required. The type of the observation
      (e.g. log, metric, etc.)
    ObserverTypeValueValuesEnum: Required. The origin of the data, e.g. user,
      system code, LLM etc.
    RelevanceOverrideValueValuesEnum: Optional. The user's relevance
      judgement.

  Messages:
    DataValue: Optional. A structured representation of the observation, as
      chosen by the observer. Optional. If present, an observer SHOULD also
      supply a text description of the observation to facilitate processing by
      an LLM and rendering in the UI.
    DataUrlsValue: Optional. A map from human-readable names to URLs for
      supportive evidence. The map key will be rendered as URL anchor text.
      Fill this in whenever an observation depends on a thing outside the
      system. For example, logging/metrics/etc query that can regenerate the
      observation.
    KnowledgeUrlsValue: Optional. A map from human-readable names to URLs for
      documentation.

  Fields:
    baseObservations: Optional. The ids of other observations that this
      observation is based on. For example, a conclusion observation will
      record the observations that were used to generate it. An extracted
      param will record what it was extracted from. The graph of premises and
      conclusions will be acyclic within a revision.
    data: Optional. A structured representation of the observation, as chosen
      by the observer. Optional. If present, an observer SHOULD also supply a
      text description of the observation to facilitate processing by an LLM
      and rendering in the UI.
    dataUrls: Optional. A map from human-readable names to URLs for supportive
      evidence. The map key will be rendered as URL anchor text. Fill this in
      whenever an observation depends on a thing outside the system. For
      example, logging/metrics/etc query that can regenerate the observation.
    id: Required. Uniquely identifies this observation. Should depend on the
      'core content' of the observation, but not e.g. on the relevance. Should
      not depend on anything that can vary unpredictably from revision to
      revision to run. This is also the map key in the parent Investigation.
      They should be hierarchical with '.' as the separator starting with the
      name of the observer. So for instance, diagnostics.runbook.ABC, or
      signals.logs, or user.input.2 It should be usable as a URL component.
      (Case-insensitive [a-z0-9-._]+) These will not be rendered for users,
      but will be visible in the data model. They will be used by Google
      engineers to localize bugs so should be semi-readable.
    knowledgeUrls: Optional. A map from human-readable names to URLs for
      documentation.
    observationCompletionState: Optional. An ObservationCompletionState
      represents whether the emitted observation is fully formed and should be
      shown the to the user. This is intended to allow hiding observations
      that are in an intermediate state.
    observationType: Required. The type of the observation (e.g. log, metric,
      etc.)
    observedNormalOperation: Optional. Whether this observation gives us
      information about an issue / root cause (false) or indicates normal
      operation (true). This is conceptually different from the relevance and
      used differently. An irrelevant observation should be hidden from the
      LLM and also the user. A relevant observation of a problem should be
      shown as an observation and should motivate a hypothesis. A relevant
      finding of normalcy may / may not be shown in the UI, but should be used
      by the LLM to filter out hypotheses that are refuted by the finding.
    observerErrors: Output only. An error within the Investigation system that
      blocked an observer from making a particular observation. The error
      string here will be shown to users. Repeated because an observer might
      lack multiple permissions. Deprecated: Use
      ObserverStatus.observer_errors instead.
    observerType: Required. The origin of the data, e.g. user, system code,
      LLM etc.
    recommendation: Optional. Natural language [markdown] text which describes
      a recommended action to remediate / fix the root cause. This is free
      form and not machine- processed at this time. A recommendation can be: -
      High-level remediation descriptions - Specific and tactical remediation
      steps with executable commands - Specific and tactical troubleshooting
      steps for where to investigate next with executable commands
    relevanceOverride: Optional. The user's relevance judgement.
    relevantResources: Optional. The Google Cloud resources relevant to the
      observation. These should be fully qualified resource URIs, e.g.,
      "//compute.googleapis.com/projects/my-project/zones/us-
      central1-a/instances/my-instance"
    systemRelevanceScore: Optional. How relevant this observation is to the
      investigation, as inferred by the system. Optional. Should be in the
      range [-1, 1]. For OBSERVATION_TYPE_HYPOTHESIS, represents confidence in
      the explanation. Only root-cause hypotheses are ranked against each
      other. For other ObservationTypes, this represents a relevance score,
      and they are ranked against each other. A value of 0 is neutral.
    text: Optional. Natural-language [markdown] text associated with the
      observation. This is the core content, not a metadata description.
    timeIntervals: Optional. When this observation occurred. Observations
      should have at least one time range so that the observations can be
      shown on a timeline and so we can find related events. For a repeated
      but not continuous event, it is appropriate to have more than one range.
      The UI may combine these.
    timeRanges: Optional. When this observation occurred. Observations should
      have at least one time range so that the observations can be shown on a
      timeline and so we can find related events. For a repeated but not
      continuous event, it is appropriate to have more than one range. The UI
      may combine these. DEPRECATED: Use time_intervals instead.
    title: Optional. The label shown in the UI. This need not be unique within
      an investigation. However, it should be specific and less than 80
      characters so that the user can easily scan across many observations.
      "Nettools pod configured with ALL capabilities dropped" is much better
      than "Interesting pod configuration".
  c                       e Zd ZdZdZdZdZy)5Observation.ObservationCompletionStateValueValuesEnuma  Optional. An ObservationCompletionState represents whether the emitted
    observation is fully formed and should be shown the to the user. This is
    intended to allow hiding observations that are in an intermediate state.

    Values:
      OBSERVATION_COMPLETION_STATE_UNSPECIFIED: Do not use.
      OBSERVATION_COMPLETION_STATE_COMPLETE: This observation is fully formed
        and should be shown the to the user.
      OBSERVATION_COMPLETION_STATE_INCOMPLETE: This observation is missing
        some information, or needs further processing by a different observer.
        This type of Observation should not be persisted into future
        investigation revisions.
    r   r   r   N)r   r   r   r   (OBSERVATION_COMPLETION_STATE_UNSPECIFIED%OBSERVATION_COMPLETION_STATE_COMPLETE'OBSERVATION_COMPLETION_STATE_INCOMPLETEr   r   r   )ObservationCompletionStateValueValuesEnumr-  K  s     01,,-)./+r   r1  c                   T    e Zd ZdZdZdZdZdZdZdZ	dZ
d	Zd
ZdZdZdZdZdZdZdZdZy)*Observation.ObservationTypeValueValuesEnuma]  Required. The type of the observation (e.g. log, metric, etc.)

    Values:
      OBSERVATION_TYPE_UNSPECIFIED: Do not use. Specify the type of the
        observation. Add a new enum if you need it.
      OBSERVATION_TYPE_CLOUD_LOG: The text of this observation is a log entry.
      OBSERVATION_TYPE_CLOUD_METRIC: The content of this observation is a
        metric or group of metrics.
      OBSERVATION_TYPE_CAIS_CONFIG: A config
      OBSERVATION_TYPE_CAIS_CONFIG_DIFF: A change of config
      OBSERVATION_TYPE_CLOUD_ALERT: An alert
      OBSERVATION_TYPE_CICD_EVENT: An event from a continuous integration
        system, e.g. prober failure.
      OBSERVATION_TYPE_TEXT_DESCRIPTION: Free text input, such as the initial
        user input. Can be markdown.
      OBSERVATION_TYPE_HYPOTHESIS: This is for [tentative] conclusions drawn
        by the system. These can become inputs to a subsequent revision. In
        this case the recommendations will be used, but not the remediation.
      OBSERVATION_TYPE_STRUCTURED_INPUT: Structured input, e.g. runbook
        parameters put into a form
      OBSERVATION_TYPE_COMPOSITE: Used for an observation that includes more
        than one kind of evidence, such as a runbook output.
      OBSERVATION_TYPE_OTHER: Runbook output can be 'other' if none of the
        other types apply.
      OBSERVATION_TYPE_RELATED_RESOURCES: Resources we think are related to
        the investigation.
      OBSERVATION_TYPE_LOG_THEME: A theme discovered in the logs.
      OBSERVATION_TYPE_CONFIG_ANALYSIS: Signals output that includes a config
        analyzed by LLM.
      OBSERVATION_TYPE_OUTAGE: Signals output that includes an outage from
        PSH.
      OBSERVATION_TYPE_KNOWLEDGE: Text that provides knowledge about a
        particular user's problem. For example, error catalog
        instructions/external links, RAG etc.
    r   r   r   r   r?   rb   r   r   r   r   r   r   r   r   r   r   r   N)r   r   r   r   OBSERVATION_TYPE_UNSPECIFIEDOBSERVATION_TYPE_CLOUD_LOGOBSERVATION_TYPE_CLOUD_METRICOBSERVATION_TYPE_CAIS_CONFIG!OBSERVATION_TYPE_CAIS_CONFIG_DIFFOBSERVATION_TYPE_CLOUD_ALERTOBSERVATION_TYPE_CICD_EVENT!OBSERVATION_TYPE_TEXT_DESCRIPTIONOBSERVATION_TYPE_HYPOTHESIS!OBSERVATION_TYPE_STRUCTURED_INPUTOBSERVATION_TYPE_COMPOSITEOBSERVATION_TYPE_OTHER"OBSERVATION_TYPE_RELATED_RESOURCESOBSERVATION_TYPE_LOG_THEME OBSERVATION_TYPE_CONFIG_ANALYSISOBSERVATION_TYPE_OUTAGEOBSERVATION_TYPE_KNOWLEDGEr   r   r   ObservationTypeValueValuesEnumr3  ]  sp    "F $% !"$%!#$ ()%#$ "#()%"#()%!#)+&!#')$ !#r   rE  c                   ,    e Zd ZdZdZdZdZdZdZdZ	dZ
y	)
'Observation.ObserverTypeValueValuesEnuma  Required. The origin of the data, e.g. user, system code, LLM etc.

    Values:
      OBSERVER_TYPE_UNSPECIFIED: Do not use. Specify where the observation
        came from. Add a new enum if you need it.
      OBSERVER_TYPE_DIAGNOSTICS: We separate these for internal attribution
        reasons. Diagnostics have an explicit notion of root causes, e.g. via
        runbooks.
      OBSERVER_TYPE_SIGNALS: Signals is for processing that doesn't have
        explicit root causes.
      OBSERVER_TYPE_DETERMINISTIC_CODE: This is for code that depends only on
        premises. In particular, error catalog lookups.
      OBSERVER_TYPE_AI: This is for AI inferences made along the way that
        depend only on observations listed as premises.
      OBSERVER_TYPE_USER: User-input observation, including answers to
        clarifications.
      OBSERVER_TYPE_ALERT: An observation from an external-to-GCA alert.
    r   r   r   r   r?   rb   r   N)r   r   r   r   OBSERVER_TYPE_UNSPECIFIEDOBSERVER_TYPE_DIAGNOSTICSOBSERVER_TYPE_SIGNALS OBSERVER_TYPE_DETERMINISTIC_CODEOBSERVER_TYPE_AIOBSERVER_TYPE_USEROBSERVER_TYPE_ALERTr   r   r   ObserverTypeValueValuesEnumrG    s3    $ !" !'($r   rO  c                       e Zd ZdZdZdZdZy),Observation.RelevanceOverrideValueValuesEnumaE  Optional. The user's relevance judgement.

    Values:
      USER_RELEVANCE_UNSPECIFIED: The user has not marked this observation as
        relevant or irrelevant.
      USER_RELEVANCE_PROMOTED: The user marked this observation as relevant.
      USER_RELEVANCE_REJECTED: The user marked this observation as irrelevant.
    r   r   r   N)r   r   r   r   USER_RELEVANCE_UNSPECIFIEDUSER_RELEVANCE_PROMOTEDUSER_RELEVANCE_REJECTEDr   r   r    RelevanceOverrideValueValuesEnumrQ    s     "#r   rU  r   c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)Observation.DataUrlsValuea  Optional. A map from human-readable names to URLs for supportive
    evidence. The map key will be rendered as URL anchor text. Fill this in
    whenever an observation depends on a thing outside the system. For
    example, logging/metrics/etc query that can regenerate the observation.

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

    Fields:
      additionalProperties: Additional properties of type DataUrlsValue
    c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy),Observation.DataUrlsValue.AdditionalPropertyzAn additional property for a DataUrlsValue object.

      Fields:
        key: Name of the additional property.
        value: A string attribute.
      r   r   Nr   r   r   r   r   rY    r   r   r   r   Tr   Nr   r   r   r   DataUrlsValuerW    r   r   rZ  c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)Observation.DataValuea  Optional. A structured representation of the observation, as chosen by
    the observer. Optional. If present, an observer SHOULD also supply a text
    description of the observation to facilitate processing by an LLM and
    rendering in the UI.

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

    Fields:
      additionalProperties: Properties of the object.
    c                   Z    e Zd ZdZ ej
                  d      Z ej                  dd      Zy)(Observation.DataValue.AdditionalPropertyzAn additional property for a DataValue object.

      Fields:
        key: Name of the additional property.
        value: A extra_types.JsonValue attribute.
      r   r$  r   Nr   r   r   r   r   r^    r%  r   r   r   Tr   Nr   r   r   r   	DataValuer\    s6    
	AY.. 	A 29112FTXYr   r_  c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)Observation.KnowledgeUrlsValuea  Optional. A map from human-readable names to URLs for documentation.

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

    Fields:
      additionalProperties: Additional properties of type KnowledgeUrlsValue
    c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)1Observation.KnowledgeUrlsValue.AdditionalPropertyzAn additional property for a KnowledgeUrlsValue object.

      Fields:
        key: Name of the additional property.
        value: A string attribute.
      r   r   Nr   r   r   r   r   rc    r   r   r   r   Tr   Nr   r   r   r   KnowledgeUrlsValuera    r   r   rd  r   Tr   r   r   r?   rb   r   r   r   r   r   r   r   r   r   r   rW   r   r   r   	TimeRange      N))r   r   r   r   r   r*   r1  rE  rO  rU  r   r   r   rZ  r_  rd  r   baseObservationsr   datadataUrlsr   knowledgeUrlsr,   observationCompletionStateobservationTyper   observedNormalOperationobserverErrorsobserverTyperecommendationrelevanceOverriderelevantResources
FloatFieldrZ   FLOATsystemRelevanceScoretexttimeIntervals
timeRangesrC   r   r   r   r   r     s^   rh0).. 0$4$y~~ 4$lINN 6    "8!!"89Zi'' Z :Z4 "8!!"89Z)## Z :Z4 "8!!"89Z9,, Z :Z0 +Y**1t<			Q	/$#Y##OQ7(yQ"()(()=qA-2y223^`ab'I''(H!L/2I2215)9))(AE.$$$%BBG,(9((,.)i))*LbQ+i++B>---b):K:K:Q:QR			r	"$()((R$G-%y%%k2E*
)


#%r   r   c                   h   e Zd ZdZ G d dej
                        Z ej                  ddd      Z ej                  d      Z
 ej                  d	      Z ej                  d
dd      Z ej                  dd      Z ej                  d      Z ej                  d      Z ej                  d      Zy)r   a  An ObserverStatus represents the status of an observer at a particular
  point during execution of an investigation. NOTE: By default, nothing in
  this message is redacted. Components should NOT put PII / CCC here except
  where redacted. Next Id: 13

  Enums:
    ObserverExecutionStateValueValuesEnum: Optional. The current execution
      state of the observer.

  Fields:
    absentObservations: Optional. The IDs of any predicate observations that
      would be needed to run this observer, but are missing. Runbook
      parameters are the motivating example. An observer must not emit an ID
      corresponding to an existing observation.
    observer: Required. The ID of the observer that this status is for.
      Observer IDs should be human-readable and hierarchical, e.g.
      "signals.logs.firewall_rules" or "diagnostics.error_catalog".
    observerDisplayName: Required. The name to show the user when describing
      this observer. Note that the UI might replace this with an
      internationalized counterpart, so it should not be generated
      dynamically. Required so that the user can see which observer (e.g.
      runbook) the system is talking about.
    observerErrors: Optional. An error within the Investigation system that
      blocked an observer from making a particular observation. The error
      string here will be shown to users. Repeated because an observer might
      lack multiple permissions.
    observerExecutionState: Optional. The current execution state of the
      observer.
    startTime: Optional. The time when the observer started. Optional because
      the observer is responsible for setting it. When the observer is
      finished, the difference between this and update_time is the observer
      run time.
    updateComment: Optional. A status update from the observer. May be logged
      for debugging purposes. These may be shown to users. A good update would
      be "parameters matched, queued for execution" or "checked log file 2/5".
    updateTime: Optional. The time when the status was updated. Optional
      because the observer is responsible for setting it. Becomes end_time
      when the observer is complete.
  c                   0    e Zd ZdZdZdZdZdZdZdZ	dZ
d	Zy
)4ObserverStatus.ObserverExecutionStateValueValuesEnuma  Optional. The current execution state of the observer.

    Values:
      OBSERVER_EXECUTION_UNSPECIFIED: The observer state is unspecified.
      OBSERVER_EXECUTION_NOT_STARTED: The investigation has not yet started.
      OBSERVER_EXECUTION_RUNNING: The investigation is running and this
        observer is runnable or running.
      OBSERVER_EXECUTION_COMPLETE: The observer has finished without an
        internal error.
      OBSERVER_EXECUTION_FAILED: The observer tried to run but failed due to
        an error. This is specific to a component and may be rendered in the
        UI if the observation is shown, as very low priority.
      OBSERVER_EXECUTION_BLOCKED: The observer is blocked pending an input.
      OBSERVER_EXECUTION_INVESTIGATION_BLOCKED: The observer reports an error
        that blocks or severely impacts the investigation, for example CAIS or
        logging disabled. Should be rendered in the UI prominently.
      OBSERVER_EXECUTION_INVESTIGATION_DEGRADED: The observer reports an error
        that degrades the investigation, may require user to escalate or re-
        run the investigation after mitigating the cause.
    r   r   r   r   r?   rb   r   r   N)r   r   r   r   OBSERVER_EXECUTION_UNSPECIFIEDOBSERVER_EXECUTION_NOT_STARTEDOBSERVER_EXECUTION_RUNNINGOBSERVER_EXECUTION_COMPLETEOBSERVER_EXECUTION_FAILEDOBSERVER_EXECUTION_BLOCKED(OBSERVER_EXECUTION_INVESTIGATION_BLOCKED)OBSERVER_EXECUTION_INVESTIGATION_DEGRADEDr   r   r   %ObserverExecutionStateValueValuesEnumr|  G  s9    ( &'"%&"!""# !!"/0,01-r   r  r	   r   Tr   r   r   r   r?   rb   r   r   r   N)r   r   r   r   r   r*   r  r   absentObservationsr   observerobserverDisplayNamero  r,   observerExecutionStater   updateCommentr   r   r   r   r   r     s    &P2inn 2< .y--.A1tT"Y""1%(-	--a0)9))(AE..9../VXYZ#i##A&)')''*-$y$$Q'*r   r   c                   r   e Zd ZdZ ej
                  d       G d dej                               Z ej
                  d       G d dej                               Z	 ej                  d      Z ej                  dd	      Z ej                  dd
      Z ej                  d      Z ej                  dd      Zy)r  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                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)Operation.MetadataValuea  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                   Z    e Zd ZdZ ej
                  d      Z ej                  dd      Zy)*Operation.MetadataValue.AdditionalPropertyr#  r   r$  r   Nr   r   r   r   r   r    r%  r   r   r   Tr   Nr   r   r   r   r&  r    s6    	AY.. 	A 29112FTXYr   r&  c                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)Operation.ResponseValuea  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                   Z    e Zd ZdZ ej
                  d      Z ej                  dd      Zy)*Operation.ResponseValue.AdditionalPropertyzAn additional property for a ResponseValue object.

      Fields:
        key: Name of the additional property.
        value: A extra_types.JsonValue attribute.
      r   r$  r   Nr   r   r   r   r   r    r%  r   r   r   Tr   Nr   r   r   r   ResponseValuer    s6     	AY.. 	A 29112FTXYr   r  r   r   r   r   r?   rb   N)r   r   r   r   r   r   r   r   r&  r  r   doner   r   r*  r   rI   responser   r   r   r  r  o  s    'R "8!!"89Zi'' Z :Z6 "8!!"89Zi'' Z :Z< 
 			"$
 )
 
 1
-%#Y##OQ7(			q	!$#Y##OQ7(r   r  c                      e Zd ZdZ ej
                  d      Z ej
                  d      Z ej
                  d      Z ej                  d      Z
 ej
                  d      Z ej
                  d      Z ej
                  d      Zy	)
OperationMetadataa  Represents the metadata of the long-running operation.

  Fields:
    apiVersion: Output only. API version used to start the operation.
    createTime: Output only. The time the operation was created.
    endTime: Output only. The time the operation finished running.
    requestedCancellation: Output only. Identifies whether the user has
      requested cancellation of the operation. Operations that have been
      cancelled successfully have Operation.error value with a
      google.rpc.Status.code of 1, corresponding to `Code.CANCELLED`.
    statusMessage: Output only. Human-readable status of the operation, if
      any.
    target: Output only. Server-defined resource path for the target of the
      operation.
    verb: Output only. Name of the verb executed by the operation.
  r   r   r   r?   rb   r   r   N)r   r   r   r   r   r   
apiVersionr   r   r   requestedCancellationstatusMessagetargetverbr   r   r   r  r    s    " %y$$Q'*$y$$Q'*!I!!!$'0)003')''*- 9  #&			q	!$r   r  c                       e Zd ZdZ ej
                  ddd      Z ej
                  ddd      Z ej                  d      Z	 ej                  d	ej                  j                  
      Zy)Policya  An Identity and Access Management (IAM) policy, which specifies access
  controls for Google Cloud resources. A `Policy` is a collection of
  `bindings`. A `binding` binds one or more `members`, or principals, to a
  single `role`. Principals can be user accounts, service accounts, Google
  groups, and domains (such as G Suite). A `role` is a named list of
  permissions; each `role` can be an IAM predefined role or a user-created
  custom role. For some types of Google Cloud resources, a `binding` can also
  specify a `condition`, which is a logical expression that allows access to a
  resource only if the expression evaluates to `true`. A condition can add
  constraints based on attributes of the request, the resource, or both. To
  learn which resources support conditions in their IAM policies, see the [IAM
  documentation](https://cloud.google.com/iam/help/conditions/resource-
  policies). **JSON example:** ``` { "bindings": [ { "role":
  "roles/resourcemanager.organizationAdmin", "members": [
  "user:mike@example.com", "group:admins@example.com", "domain:google.com",
  "serviceAccount:my-project-id@appspot.gserviceaccount.com" ] }, { "role":
  "roles/resourcemanager.organizationViewer", "members": [
  "user:eve@example.com" ], "condition": { "title": "expirable access",
  "description": "Does not grant access after Sep 2020", "expression":
  "request.time < timestamp('2020-10-01T00:00:00.000Z')", } } ], "etag":
  "BwWWja0YfJA=", "version": 3 } ``` **YAML example:** ``` bindings: -
  members: - user:mike@example.com - group:admins@example.com -
  domain:google.com - serviceAccount:my-project-id@appspot.gserviceaccount.com
  role: roles/resourcemanager.organizationAdmin - members: -
  user:eve@example.com role: roles/resourcemanager.organizationViewer
  condition: title: expirable access description: Does not grant access after
  Sep 2020 expression: request.time < timestamp('2020-10-01T00:00:00.000Z')
  etag: BwWWja0YfJA= version: 3 ``` For a description of IAM and its features,
  see the [IAM documentation](https://cloud.google.com/iam/docs/).

  Fields:
    auditConfigs: Specifies cloud audit logging configuration for this policy.
    bindings: Associates a list of `members`, or principals, with a `role`.
      Optionally, may specify a `condition` that determines how and when the
      `bindings` are applied. Each of the `bindings` must contain at least one
      principal. The `bindings` in a `Policy` can refer to up to 1,500
      principals; up to 250 of these principals can be Google groups. Each
      occurrence of a principal counts towards these limits. For example, if
      the `bindings` grant 50 different roles to `user:alice@example.com`, and
      not to any other principal, then you can add another 1,450 principals to
      the `bindings` in the `Policy`.
    etag: `etag` is used for optimistic concurrency control as a way to help
      prevent simultaneous updates of a policy from overwriting each other. It
      is strongly suggested that systems make use of the `etag` in the read-
      modify-write cycle to perform policy updates in order to avoid race
      conditions: An `etag` is returned in the response to `getIamPolicy`, and
      systems are expected to put that etag in the request to `setIamPolicy`
      to ensure that their change will be applied to the same version of the
      policy. **Important:** If you use IAM Conditions, you must include the
      `etag` field whenever you call `setIamPolicy`. If you omit this field,
      then IAM allows you to overwrite a version `3` policy with a version `1`
      policy, and all of the conditions in the version `3` policy are lost.
    version: Specifies the format of the policy. Valid values are `0`, `1`,
      and `3`. Requests that specify an invalid value are rejected. Any
      operation that affects conditional role bindings must specify version
      `3`. This requirement applies to the following operations: * Getting a
      policy that includes a conditional role binding * Adding a conditional
      role binding to a policy * Changing a conditional role binding in a
      policy * Removing any role binding, with or without a condition, from a
      policy that includes conditions **Important:** If you use IAM
      Conditions, you must include the `etag` field whenever you call
      `setIamPolicy`. If you omit this field, then IAM allows you to overwrite
      a version `3` policy with a version `1` policy, and all of the
      conditions in the version `3` policy are lost. If a policy does not
      include any conditions, operations on that policy may specify any valid
      version or leave the field unset. To learn which resources support
      conditions in their IAM policies, see the [IAM
      documentation](https://cloud.google.com/iam/help/conditions/resource-
      policies).
  r   r   Tr   r/   r   r   r?   rW   N)r   r   r   r   r   r   auditConfigsbindings
BytesFieldetagrY   rZ   r[   versionr   r   r   r  r    si    EN (''q4H,#Y##Iq4@(			a	 $"I""1i.?.?.E.EF'r   r  c                       e Zd ZdZ ej
                  dd      Z ej                  d      Z ej
                  dd      Z	y)ry   aK  Request for running an investigation at a particular revision.

  Fields:
    runParameters: Optional. Parameters to pass through to Titan.
    updateMask: Optional. The fields of the revision to update. Note that only
      user-writeable fields can be updated.
    updatedRevision: Optional. Revision to update before running.
  r  r   r   rl   r   N)
r   r   r   r   r   r   runParametersr   ri   updatedRevisionr   r   r   ry   ry   D  sE     ))(()EqI-$y$$Q'**I**+BAF/r   ry   c                       e Zd ZdZ ej
                  dd      Z ej
                  d      Z ej
                  d      Z ej
                  dd      Z	 ej
                  d      Z
 ej
                  d	      Zy
)r9   a(  Parameter metadata for runbooks updated by the Diagnostic task.

  Fields:
    associatedAssetTypes: Optional. If present, a list of resource types that
      this parameter might be. For example, "compute.googleapis.com/Instance".
    description: Optional. The description of the parameter.
    displayName: Optional. The name of the parameter to be displayed to the
      user.
    exampleValues: Optional. Examples of the parameter value.
    id: Optional. The name of the parameter.
    value: Optional. The value of the parameter if available.
  r   Tr   r   r   r?   rb   r   N)r   r   r   r   r   r   associatedAssetTypesr@   r(  exampleValuesr   r   r   r   r   r9   r9   S  sz     /..q4@%	%%a(+%	%%a(+')''D9-yQ"
)


"%r   r9   c                   Z    e Zd ZdZ ej
                  dd      Z ej                  d      Zy)r}   a  Request message for `SetIamPolicy` method.

  Fields:
    policy: REQUIRED: The complete policy to be applied to the `resource`. The
      size of the policy is limited to a few 10s of KB. An empty policy is a
      valid policy but certain Google Cloud services (such as Projects) might
      reject them.
    updateMask: OPTIONAL: A FieldMask specifying which fields of the policy to
      modify. Only the fields in the mask will be modified. If no mask is
      provided, the following default mask is used: `paths: "bindings, etag"`
  r  r   r   N)	r   r   r   r   r   r   policyr   ri   r   r   r   r}   r}   i  s/    
 "9!!(A.&$y$$Q'*r   r}   c                       e Zd ZdZ G d dej
                        Z G d dej
                        Z ej                  dd      Z	 ej                  d      Z ej                  ddd	
      Z ej                  d      Z ej                  d      Z ej                  d      Z ej                  d      Z ej"                  dd
      Z ej                  d      Z ej                  d      Z ej                  d      Z ej                  d      Zy)StandardQueryParametersa4  Query parameters accepted by all methods.

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

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

    Values:
      json: Responses with Content-Type of application/json
      media: Media download with context-dependent Content-Type
      proto: Responses with Content-Type of application/x-protobuf
    r   r   r   N)r   r   r   r   jsonmediaprotor   r   r   AltValueValuesEnumr    s     DEEr   r  c                       e Zd ZdZdZdZy)-StandardQueryParameters.FXgafvValueValuesEnumzVV1 error format.

    Values:
      _1: v1 error format
      _2: v2 error format
    r   r   N)r   r   r   r   _1_2r   r   r   FXgafvValueValuesEnumr    s     
B	
Br   r  r   r   r   r  )defaultr?   rb   r   r   r   Tr   r   r   r   N)r   r   r   r   r   r*   r  r  r,   f__xgafvr   access_tokenaltcallbackfieldsr   oauth_tokenr   prettyPrint	quotaUsertrace
uploadTypeupload_protocolr   r   r   r  r  z  s   4
9>> 
inn  !Y  !8!<(&&&q),	0!VD#"Y""1%( 9  #&	a #%	%%a(+&	&&q$7+#i##A&)
)


#%$y$$R(*)I))"-/r   r  c                      e Zd ZdZ ej
                  d       G d dej                               Z ej                  dej                  j                        Z ej                  ddd	      Z ej                  d
      Zy)r   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                   d    e Zd ZdZ G d dej
                        Z ej                  ddd      Zy)Status.DetailsValueListEntryzA DetailsValueListEntry object.

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

    Fields:
      additionalProperties: Properties of the object. Contains field @type
        with type URL.
    c                   Z    e Zd ZdZ ej
                  d      Z ej                  dd      Zy)/Status.DetailsValueListEntry.AdditionalPropertyzAn additional property for a DetailsValueListEntry object.

      Fields:
        key: Name of the additional property.
        value: A extra_types.JsonValue attribute.
      r   r$  r   Nr   r   r   r   r   r    r%  r   r   r   Tr   Nr   r   r   r   DetailsValueListEntryr    r'  r   r  r   rW   r   Tr   r   N)r   r   r   r   r   r   r   r   r  rY   rZ   r[   coder   detailsr   messager   r   r   r   r     s    & "8!!"89Zi// Z :Z2 
 		9+<+<+B+B	C$"I""#:AM'!I!!!$'r   r   c                   8    e Zd ZdZ ej
                  dd      Zy)r   a?  Request message for `TestIamPermissions` method.

  Fields:
    permissions: The set of permissions to check for the `resource`.
      Permissions with wildcards (such as `*` or `storage.*`) are not allowed.
      For more information see [IAM
      Overview](https://cloud.google.com/iam/docs/overview#permissions).
  r   Tr   Nr   r   r   r   r   r   permissionsr   r   r   r   r     s     &	%%a$7+r   r   c                   8    e Zd ZdZ ej
                  dd      Zy)TestIamPermissionsResponsezResponse message for `TestIamPermissions` method.

  Fields:
    permissions: A subset of `TestPermissionsRequest.permissions` that the
      caller is allowed.
  r   Tr   Nr  r   r   r   r  r    s     &	%%a$7+r   r  c                   X    e Zd ZdZ ej
                  d      Z ej
                  d      Zy)re  a}  Represents a time range at which an observation applies DEPRECATED: Use
  google.type.Interval instead.

  Fields:
    endTime: If end is unspecified, that implies that it continues to the
      present. Use end==start for a single moment.
    startTime: When this observation began applying. Use 'now' if the observer
      is just looking at the current state of Google Cloud.
  r   r   Nr   r   r   r   re  re    s-     "I!!!$'#i##A&)r   re  r  z$.xgafvr  1r  2r\   zoptions.requestedPolicyVersionN)Br   
__future__r   apitools.base.protorpcliter   r   apitools.base.pyr   r   packager   r	   r   r   r/   r5   r8   r=   r0   rE   rL   rS   rV   r_   ra   rh   rk   rp   rr   rt   rv   rx   r|   r   r   r   r   r   r   r
   r   rM   r   rl   r  r  r  r  r  r  r   r   r  r  r  ry   r9   r}   r  r   r   r  re  AddCustomJsonFieldMappingAddCustomJsonEnumMappingr  r   r   r   <module>r     sh   ' < % ( 0	)) 0$%)## %:=Y&& =DT"i T"n=Y.. =C)++ C"I !#9 !#H193D3D 1'IDUDU ':'IDUDU ',5)J[J[ 561ARAR 13)BSBS 3((9CTCT (>'YM^M^ '<'YM^M^ '.1)J[J[ 139K\K\ 3"(IL]L] (Ba)J[J[ a I)J[J[ I"UPYPaPa U$'I4E4E '.
1	@Q@Q 
11	@Q@Q 11Y=N=N 1'i>O>O ' -y00 -"'y   '$G)I%% G)TJ*y00 J*Z+8I-- +8\&@!2!2 &@R8):): 88!2!2 8
+I-- 
+
EY.. 
EM"y   M"`E$)## E$P
N(Y&& N(bi8	!! i8X"	)) "6KGY KG\Gi&7&7 G#y(( #,()++ ("<.i// <.~0%Y 0%f
8	 1 1 
88!2!2 8'	!! ' # " "Z4 ! ! !114> ! ! !114> " " "GIi  lLMr   