{
  "documentationLink": "https://cloud.google.com/document-warehouse",
  "baseUrl": "https://contentwarehouse.googleapis.com/",
  "revision": "20250206",
  "batchPath": "batch",
  "rootUrl": "https://contentwarehouse.googleapis.com/",
  "parameters": {
    "oauth_token": {
      "description": "OAuth 2.0 token for the current user.",
      "location": "query",
      "type": "string"
    },
    "prettyPrint": {
      "type": "boolean",
      "default": "true",
      "location": "query",
      "description": "Returns response with indentations and line breaks."
    },
    "callback": {
      "description": "JSONP",
      "location": "query",
      "type": "string"
    },
    "$.xgafv": {
      "enum": [
        "1",
        "2"
      ],
      "description": "V1 error format.",
      "location": "query",
      "enumDescriptions": [
        "v1 error format",
        "v2 error format"
      ],
      "type": "string"
    },
    "key": {
      "type": "string",
      "location": "query",
      "description": "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."
    },
    "uploadType": {
      "type": "string",
      "description": "Legacy upload protocol for media (e.g. \"media\", \"multipart\").",
      "location": "query"
    },
    "fields": {
      "description": "Selector specifying which fields to include in a partial response.",
      "location": "query",
      "type": "string"
    },
    "alt": {
      "default": "json",
      "description": "Data format for response.",
      "location": "query",
      "enum": [
        "json",
        "media",
        "proto"
      ],
      "enumDescriptions": [
        "Responses with Content-Type of application/json",
        "Media download with context-dependent Content-Type",
        "Responses with Content-Type of application/x-protobuf"
      ],
      "type": "string"
    },
    "quotaUser": {
      "type": "string",
      "location": "query",
      "description": "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."
    },
    "access_token": {
      "location": "query",
      "type": "string",
      "description": "OAuth access token."
    },
    "upload_protocol": {
      "location": "query",
      "type": "string",
      "description": "Upload protocol for media (e.g. \"raw\", \"multipart\")."
    }
  },
  "servicePath": "",
  "icons": {
    "x16": "http://www.google.com/images/icons/product/search-16.gif",
    "x32": "http://www.google.com/images/icons/product/search-32.gif"
  },
  "fullyEncodeReservedExpansion": true,
  "ownerDomain": "google.com",
  "version_module": true,
  "mtlsRootUrl": "https://contentwarehouse.mtls.googleapis.com/",
  "description": "",
  "schemas": {
    "GoogleCloudDocumentaiV1Document": {
      "type": "object",
      "description": "Document represents the canonical document resource in Document AI. It is an interchange format that provides insights into documents and allows for collaboration between users and Document AI to iterate and optimize for quality.",
      "id": "GoogleCloudDocumentaiV1Document",
      "properties": {
        "error": {
          "description": "Any error that occurred while processing this document.",
          "$ref": "GoogleRpcStatus"
        },
        "textStyles": {
          "deprecated": true,
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentStyle"
          },
          "description": "Styles for the Document.text.",
          "type": "array"
        },
        "text": {
          "type": "string",
          "description": "Optional. UTF-8 encoded text in reading order from the document."
        },
        "revisions": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentRevision"
          },
          "type": "array",
          "description": "Placeholder. Revision history of this document."
        },
        "shardInfo": {
          "description": "Information about the sharding if this document is sharded part of a larger document. If the document is not sharded, this message is not specified.",
          "$ref": "GoogleCloudDocumentaiV1DocumentShardInfo"
        },
        "pages": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPage"
          },
          "type": "array",
          "description": "Visual page layout for the Document."
        },
        "content": {
          "format": "byte",
          "type": "string",
          "description": "Optional. Inline document content, represented as a stream of bytes. Note: As with all `bytes` fields, protobuffers use a pure binary representation, whereas JSON representations use base64."
        },
        "entities": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentEntity"
          },
          "description": "A list of entities detected on Document.text. For document shards, entities in this list may cross shard boundaries.",
          "type": "array"
        },
        "mimeType": {
          "type": "string",
          "description": "An IANA published [media type (MIME type)](https://www.iana.org/assignments/media-types/media-types.xhtml)."
        },
        "entityRelations": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentEntityRelation"
          },
          "description": "Placeholder. Relationship among Document.entities."
        },
        "textChanges": {
          "type": "array",
          "description": "Placeholder. A list of text corrections made to Document.text. This is usually used for annotating corrections to OCR mistakes. Text changes for a given revision may not overlap with each other.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentTextChange"
          }
        },
        "documentLayout": {
          "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayout",
          "description": "Parsed layout of the document."
        },
        "uri": {
          "type": "string",
          "description": "Optional. Currently supports Google Cloud Storage URI of the form `gs://bucket_name/object_name`. Object versioning is not supported. For more information, refer to [Google Cloud Storage Request URIs](https://cloud.google.com/storage/docs/reference-uris)."
        },
        "chunkedDocument": {
          "$ref": "GoogleCloudDocumentaiV1DocumentChunkedDocument",
          "description": "Document chunked based on chunking config."
        }
      }
    },
    "CloudAiPlatformTenantresourceIamPolicyBinding": {
      "id": "CloudAiPlatformTenantresourceIamPolicyBinding",
      "type": "object",
      "properties": {
        "resourceType": {
          "enum": [
            "RESOURCE_TYPE_UNSPECIFIED",
            "PROJECT",
            "SERVICE_ACCOUNT",
            "GCS_BUCKET",
            "SERVICE_CONSUMER",
            "AR_REPO"
          ],
          "enumDescriptions": [
            "",
            "The value of resource field is the ID or number of a project. Format is ",
            "The value of resource field is the resource name of a service account. Format is projects//serviceAccounts/",
            "The value of resource field is the name of a GCS bucket (not its resource name). Format is .",
            "The value of resource field is the resource name of a service consumer. Format is services//consumers/",
            "The value of the resource field is the AR Image Uri which identifies an AR REPO. Allowed formats are: /// ///: ///@"
          ],
          "description": "Input/Output [Required]. Specifies the type of resource that will be accessed by members.",
          "type": "string"
        },
        "resource": {
          "description": "Input/Output [Required]. The resource name that will be accessed by members, which also depends on resource_type. Note: placeholders are supported in resource names. For example, ${tpn} will be used when the tenant project number is not ready.",
          "type": "string"
        },
        "role": {
          "type": "string",
          "description": "Input/Output [Required]. The role for members below."
        },
        "members": {
          "items": {
            "type": "string"
          },
          "type": "array",
          "description": "Input/Output [Required]. The member service accounts with the roles above. Note: placeholders are same as the resource above."
        }
      },
      "description": "The dynamic IAM bindings to be granted after tenant projects are created."
    },
    "GoogleCloudContentwarehouseV1UpdateDocumentSchemaRequest": {
      "type": "object",
      "properties": {
        "documentSchema": {
          "description": "Required. The document schema to update with.",
          "$ref": "GoogleCloudContentwarehouseV1DocumentSchema"
        }
      },
      "id": "GoogleCloudContentwarehouseV1UpdateDocumentSchemaRequest",
      "description": "Request message for DocumentSchemaService.UpdateDocumentSchema."
    },
    "GoogleCloudContentwarehouseV1DocumentLink": {
      "id": "GoogleCloudContentwarehouseV1DocumentLink",
      "description": "A document-link between source and target document.",
      "properties": {
        "targetDocumentReference": {
          "$ref": "GoogleCloudContentwarehouseV1DocumentReference",
          "description": "Document references of the target document."
        },
        "sourceDocumentReference": {
          "description": "Document references of the source document.",
          "$ref": "GoogleCloudContentwarehouseV1DocumentReference"
        },
        "description": {
          "description": "Description of this document-link.",
          "type": "string"
        },
        "createTime": {
          "type": "string",
          "readOnly": true,
          "format": "google-datetime",
          "description": "Output only. The time when the documentLink is created."
        },
        "updateTime": {
          "description": "Output only. The time when the documentLink is last updated.",
          "readOnly": true,
          "type": "string",
          "format": "google-datetime"
        },
        "name": {
          "type": "string",
          "description": "Name of this document-link. It is required that the parent derived form the name to be consistent with the source document reference. Otherwise an exception will be thrown. Format: projects/{project_number}/locations/{location}/documents/{source_document_id}/documentLinks/{document_link_id}."
        },
        "state": {
          "type": "string",
          "enumDescriptions": [
            "Unknown state of documentlink.",
            "The documentlink has both source and target documents detected.",
            "Target document is deleted, and mark the documentlink as soft-deleted."
          ],
          "enum": [
            "STATE_UNSPECIFIED",
            "ACTIVE",
            "SOFT_DELETED"
          ],
          "description": "The state of the documentlink. If target node has been deleted, the link is marked as invalid. Removing a source node will result in removal of all associated links."
        }
      },
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1UpdateOptions": {
      "properties": {
        "updateType": {
          "type": "string",
          "enumDescriptions": [
            "Defaults to full replace behavior, ie. FULL_REPLACE.",
            "Fully replace all the fields (including previously linked raw document). Any field masks will be ignored.",
            "Merge the fields into the existing entities.",
            "Inserts the properties by names.",
            "Replace the properties by names.",
            "Delete the properties by names.",
            "For each of the property, replaces the property if the it exists, otherwise inserts a new property. And for the rest of the fields, merge them based on update mask and merge fields options."
          ],
          "description": "Type for update.",
          "enum": [
            "UPDATE_TYPE_UNSPECIFIED",
            "UPDATE_TYPE_REPLACE",
            "UPDATE_TYPE_MERGE",
            "UPDATE_TYPE_INSERT_PROPERTIES_BY_NAMES",
            "UPDATE_TYPE_REPLACE_PROPERTIES_BY_NAMES",
            "UPDATE_TYPE_DELETE_PROPERTIES_BY_NAMES",
            "UPDATE_TYPE_MERGE_AND_REPLACE_OR_INSERT_PROPERTIES_BY_NAMES"
          ]
        },
        "mergeFieldsOptions": {
          "description": "Options for merging.",
          "$ref": "GoogleCloudContentwarehouseV1MergeFieldsOptions"
        },
        "updateMask": {
          "type": "string",
          "format": "google-fieldmask",
          "description": "Field mask for merging Document fields. For the `FieldMask` definition, see https://developers.google.com/protocol-buffers/docs/reference/google.protobuf#fieldmask"
        }
      },
      "description": "Options for Update operations.",
      "id": "GoogleCloudContentwarehouseV1UpdateOptions",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1CloudAIDocumentOption": {
      "properties": {
        "customizedEntitiesPropertiesConversions": {
          "type": "object",
          "description": "If set, only selected entities will be converted to properties.",
          "additionalProperties": {
            "type": "string"
          }
        },
        "enableEntitiesConversions": {
          "description": "Whether to convert all the entities to properties.",
          "type": "boolean"
        }
      },
      "description": "Request Option for processing Cloud AI Document in CW Document.",
      "id": "GoogleCloudContentwarehouseV1CloudAIDocumentOption",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1DataValidationAction": {
      "type": "object",
      "description": "Represents the action responsible for data validation operations.",
      "properties": {
        "conditions": {
          "type": "object",
          "additionalProperties": {
            "type": "string"
          },
          "description": "Map of (K, V) -\u003e (field, string condition to be evaluated on the field) E.g., (\"age\", \"age \u003e 18 && age \u003c 60\") entry triggers validation of field age with the given condition. Map entries will be ANDed during validation."
        }
      },
      "id": "GoogleCloudContentwarehouseV1DataValidationAction"
    },
    "GoogleCloudDocumentaiV1DocumentPageVisualElement": {
      "description": "Detected non-text visual elements e.g. checkbox, signature etc. on the page.",
      "id": "GoogleCloudDocumentaiV1DocumentPageVisualElement",
      "type": "object",
      "properties": {
        "type": {
          "type": "string",
          "description": "Type of the VisualElement."
        },
        "detectedLanguages": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage"
          },
          "type": "array",
          "description": "A list of detected languages together with confidence."
        },
        "layout": {
          "description": "Layout for VisualElement.",
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout"
        }
      }
    },
    "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlock": {
      "type": "object",
      "properties": {
        "blockId": {
          "description": "ID of the block.",
          "type": "string"
        },
        "textBlock": {
          "description": "Block consisting of text content.",
          "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTextBlock"
        },
        "listBlock": {
          "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutListBlock",
          "description": "Block consisting of list content/structure."
        },
        "pageSpan": {
          "description": "Page span of the block.",
          "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutPageSpan"
        },
        "tableBlock": {
          "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTableBlock",
          "description": "Block consisting of table content/structure."
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlock",
      "description": "Represents a block. A block could be one of the various types (text, table, list) supported."
    },
    "GoogleCloudDocumentaiV1DocumentPageAnchorPageRef": {
      "properties": {
        "layoutId": {
          "type": "string",
          "deprecated": true,
          "description": "Optional. Deprecated. Use PageRef.bounding_poly instead."
        },
        "boundingPoly": {
          "description": "Optional. Identifies the bounding polygon of a layout element on the page. If `layout_type` is set, the bounding polygon must be exactly the same to the layout element it's referring to.",
          "$ref": "GoogleCloudDocumentaiV1BoundingPoly"
        },
        "layoutType": {
          "enumDescriptions": [
            "Layout Unspecified.",
            "References a Page.blocks element.",
            "References a Page.paragraphs element.",
            "References a Page.lines element.",
            "References a Page.tokens element.",
            "References a Page.visual_elements element.",
            "Refrrences a Page.tables element.",
            "References a Page.form_fields element."
          ],
          "enum": [
            "LAYOUT_TYPE_UNSPECIFIED",
            "BLOCK",
            "PARAGRAPH",
            "LINE",
            "TOKEN",
            "VISUAL_ELEMENT",
            "TABLE",
            "FORM_FIELD"
          ],
          "description": "Optional. The type of the layout element that is being referenced if any.",
          "type": "string"
        },
        "page": {
          "format": "int64",
          "type": "string",
          "description": "Required. Index into the Document.pages element, for example using `Document.pages` to locate the related page element. This field is skipped when its value is the default `0`. See https://developers.google.com/protocol-buffers/docs/proto3#json."
        },
        "confidence": {
          "type": "number",
          "format": "float",
          "description": "Optional. Confidence of detected page element, if applicable. Range `[0, 1]`."
        }
      },
      "description": "Represents a weak reference to a page element within a document.",
      "id": "GoogleCloudDocumentaiV1DocumentPageAnchorPageRef",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1IntegerArray": {
      "type": "object",
      "description": "Integer values.",
      "id": "GoogleCloudContentwarehouseV1IntegerArray",
      "properties": {
        "values": {
          "items": {
            "format": "int32",
            "type": "integer"
          },
          "description": "List of integer values.",
          "type": "array"
        }
      }
    },
    "GoogleCloudContentwarehouseV1RequestMetadata": {
      "id": "GoogleCloudContentwarehouseV1RequestMetadata",
      "properties": {
        "userInfo": {
          "$ref": "GoogleCloudContentwarehouseV1UserInfo",
          "description": "Provides user unique identification and groups information."
        }
      },
      "description": "Meta information is used to improve the performance of the service.",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1EnumValue": {
      "description": "Represents the string value of the enum field.",
      "id": "GoogleCloudContentwarehouseV1EnumValue",
      "type": "object",
      "properties": {
        "value": {
          "type": "string",
          "description": "String value of the enum field. This must match defined set of enums in document schema using EnumTypeOptions."
        }
      }
    },
    "GoogleCloudContentwarehouseV1ProcessWithDocAiPipeline": {
      "description": "The configuration of processing documents in Document Warehouse with DocAi processors pipeline.",
      "type": "object",
      "properties": {
        "processorInfo": {
          "description": "The CDW processor information.",
          "$ref": "GoogleCloudContentwarehouseV1ProcessorInfo"
        },
        "documents": {
          "description": "The list of all the resource names of the documents to be processed. Format: projects/{project_number}/locations/{location}/documents/{document_id}.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "exportFolderPath": {
          "description": "The Cloud Storage folder path used to store the exported documents before being sent to CDW. Format: `gs:///`.",
          "type": "string"
        },
        "processorResultsFolderPath": {
          "type": "string",
          "description": "The Cloud Storage folder path used to store the raw results from processors. Format: `gs:///`."
        }
      },
      "id": "GoogleCloudContentwarehouseV1ProcessWithDocAiPipeline"
    },
    "GoogleCloudDocumentaiV1DocumentEntityRelation": {
      "type": "object",
      "properties": {
        "subjectId": {
          "description": "Subject entity id.",
          "type": "string"
        },
        "relation": {
          "description": "Relationship description.",
          "type": "string"
        },
        "objectId": {
          "type": "string",
          "description": "Object entity id."
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentEntityRelation",
      "description": "Relationship between Entities."
    },
    "GoogleCloudDocumentaiV1DocumentEntityNormalizedValue": {
      "type": "object",
      "description": "Parsed and normalized entity value.",
      "id": "GoogleCloudDocumentaiV1DocumentEntityNormalizedValue",
      "properties": {
        "text": {
          "description": "Optional. An optional field to store a normalized string. For some entity types, one of respective `structured_value` fields may also be populated. Also not all the types of `structured_value` will be normalized. For example, some processors may not generate `float` or `integer` normalized text by default. Below are sample formats mapped to structured values. - Money/Currency type (`money_value`) is in the ISO 4217 text format. - Date type (`date_value`) is in the ISO 8601 text format. - Datetime type (`datetime_value`) is in the ISO 8601 text format.",
          "type": "string"
        },
        "addressValue": {
          "$ref": "GoogleTypePostalAddress",
          "description": "Postal address. See also: https://github.com/googleapis/googleapis/blob/master/google/type/postal_address.proto"
        },
        "dateValue": {
          "description": "Date value. Includes year, month, day. See also: https://github.com/googleapis/googleapis/blob/master/google/type/date.proto",
          "$ref": "GoogleTypeDate"
        },
        "floatValue": {
          "type": "number",
          "description": "Float value.",
          "format": "float"
        },
        "moneyValue": {
          "$ref": "GoogleTypeMoney",
          "description": "Money value. See also: https://github.com/googleapis/googleapis/blob/master/google/type/money.proto"
        },
        "datetimeValue": {
          "description": "DateTime value. Includes date, time, and timezone. See also: https://github.com/googleapis/googleapis/blob/master/google/type/datetime.proto",
          "$ref": "GoogleTypeDateTime"
        },
        "integerValue": {
          "type": "integer",
          "format": "int32",
          "description": "Integer value."
        },
        "booleanValue": {
          "type": "boolean",
          "description": "Boolean value. Can be used for entities with binary values, or for checkboxes."
        }
      }
    },
    "GoogleCloudContentwarehouseV1DateTimeArray": {
      "description": "DateTime values.",
      "id": "GoogleCloudContentwarehouseV1DateTimeArray",
      "properties": {
        "values": {
          "description": "List of datetime values. Both OffsetDateTime and ZonedDateTime are supported.",
          "type": "array",
          "items": {
            "$ref": "GoogleTypeDateTime"
          }
        }
      },
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1ListLinkedSourcesResponse": {
      "description": "Response message for DocumentLinkService.ListLinkedSources.",
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1ListLinkedSourcesResponse",
      "properties": {
        "documentLinks": {
          "description": "Source document-links.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1DocumentLink"
          }
        },
        "nextPageToken": {
          "type": "string",
          "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages."
        }
      }
    },
    "GoogleIamV1Binding": {
      "id": "GoogleIamV1Binding",
      "type": "object",
      "description": "Associates `members`, or principals, with a `role`.",
      "properties": {
        "condition": {
          "description": "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).",
          "$ref": "GoogleTypeExpr"
        },
        "role": {
          "description": "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).",
          "type": "string"
        },
        "members": {
          "items": {
            "type": "string"
          },
          "description": "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/locations/global/workforcePools/{pool_id}/subject/{subject_attribute_value}`: A single identity in a workforce identity pool. * `principalSet://iam.googleapis.com/locations/global/workforcePools/{pool_id}/group/{group_id}`: All workforce identities in a group. * `principalSet://iam.googleapis.com/locations/global/workforcePools/{pool_id}/attribute.{attribute_name}/{attribute_value}`: All workforce identities with a specific attribute value. * `principalSet://iam.googleapis.com/locations/global/workforcePools/{pool_id}/*`: All identities in a workforce identity pool. * `principal://iam.googleapis.com/projects/{project_number}/locations/global/workloadIdentityPools/{pool_id}/subject/{subject_attribute_value}`: A single identity in a workload identity pool. * `principalSet://iam.googleapis.com/projects/{project_number}/locations/global/workloadIdentityPools/{pool_id}/group/{group_id}`: A workload identity pool group. * `principalSet://iam.googleapis.com/projects/{project_number}/locations/global/workloadIdentityPools/{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/global/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.googleapis.com/locations/global/workforcePools/{pool_id}/subject/{subject_attribute_value}`: Deleted single identity in a workforce identity pool. For example, `deleted:principal://iam.googleapis.com/locations/global/workforcePools/my-pool-id/subject/my-subject-attribute-value`.",
          "type": "array"
        }
      }
    },
    "GoogleCloudContentwarehouseV1PropertyTypeOptions": {
      "type": "object",
      "description": "Configurations for a nested structured data property.",
      "properties": {
        "propertyDefinitions": {
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1PropertyDefinition"
          },
          "description": "Required. List of property definitions.",
          "type": "array"
        }
      },
      "id": "GoogleCloudContentwarehouseV1PropertyTypeOptions"
    },
    "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTableCell": {
      "description": "Represents a cell in a table row.",
      "id": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTableCell",
      "type": "object",
      "properties": {
        "colSpan": {
          "type": "integer",
          "format": "int32",
          "description": "How many columns this cell spans."
        },
        "rowSpan": {
          "type": "integer",
          "format": "int32",
          "description": "How many rows this cell spans."
        },
        "blocks": {
          "description": "A table cell is a list of blocks. Repeated blocks support further hierarchies and nested blocks.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlock"
          },
          "type": "array"
        }
      }
    },
    "GoogleCloudContentwarehouseV1Rule": {
      "description": "Represents the rule for a content warehouse trigger.",
      "properties": {
        "condition": {
          "description": "Represents the conditional expression to be evaluated. Expression should evaluate to a boolean result. When the condition is true actions are executed. Example: user_role = \"hsbc_role_1\" AND doc.salary \u003e 20000",
          "type": "string"
        },
        "triggerType": {
          "enum": [
            "UNKNOWN",
            "ON_CREATE",
            "ON_UPDATE",
            "ON_CREATE_LINK",
            "ON_DELETE_LINK"
          ],
          "enumDescriptions": [
            "Trigger for unknown action.",
            "Trigger for create document action.",
            "Trigger for update document action.",
            "Trigger for create link action.",
            "Trigger for delete link action."
          ],
          "description": "Identifies the trigger type for running the policy.",
          "type": "string"
        },
        "actions": {
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1Action"
          },
          "type": "array",
          "description": "List of actions that are executed when the rule is satisfied."
        },
        "description": {
          "type": "string",
          "description": "Short description of the rule and its context."
        },
        "ruleId": {
          "description": "ID of the rule. It has to be unique across all the examples. This is managed internally.",
          "type": "string"
        }
      },
      "id": "GoogleCloudContentwarehouseV1Rule",
      "type": "object"
    },
    "GoogleCloudDocumentaiV1DocumentPageTableTableRow": {
      "properties": {
        "cells": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageTableTableCell"
          },
          "description": "Cells that make up this row.",
          "type": "array"
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentPageTableTableRow",
      "description": "A row of table cells.",
      "type": "object"
    },
    "GoogleTypeColor": {
      "properties": {
        "red": {
          "type": "number",
          "format": "float",
          "description": "The amount of red in the color as a value in the interval [0, 1]."
        },
        "green": {
          "type": "number",
          "description": "The amount of green in the color as a value in the interval [0, 1].",
          "format": "float"
        },
        "blue": {
          "format": "float",
          "description": "The amount of blue in the color as a value in the interval [0, 1].",
          "type": "number"
        },
        "alpha": {
          "type": "number",
          "description": "The fraction of this color that should be applied to the pixel. That is, the final pixel color is defined by the equation: `pixel color = alpha * (this color) + (1.0 - alpha) * (background color)` This means that a value of 1.0 corresponds to a solid color, whereas a value of 0.0 corresponds to a completely transparent color. This uses a wrapper message rather than a simple float scalar so that it is possible to distinguish between a default value and the value being unset. If omitted, this color object is rendered as a solid color (as if the alpha value had been explicitly given a value of 1.0).",
          "format": "float"
        }
      },
      "description": "Represents a color in the RGBA color space. This representation is designed for simplicity of conversion to and from color representations in various languages over compactness. For example, the fields of this representation can be trivially provided to the constructor of `java.awt.Color` in Java; it can also be trivially provided to UIColor's `+colorWithRed:green:blue:alpha` method in iOS; and, with just a little work, it can be easily formatted into a CSS `rgba()` string in JavaScript. This reference page doesn't have information about the absolute color space that should be used to interpret the RGB value—for example, sRGB, Adobe RGB, DCI-P3, and BT.2020. By default, applications should assume the sRGB color space. When color equality needs to be decided, implementations, unless documented otherwise, treat two colors as equal if all their red, green, blue, and alpha values each differ by at most `1e-5`. Example (Java): import com.google.type.Color; // ... public static java.awt.Color fromProto(Color protocolor) { float alpha = protocolor.hasAlpha() ? protocolor.getAlpha().getValue() : 1.0; return new java.awt.Color( protocolor.getRed(), protocolor.getGreen(), protocolor.getBlue(), alpha); } public static Color toProto(java.awt.Color color) { float red = (float) color.getRed(); float green = (float) color.getGreen(); float blue = (float) color.getBlue(); float denominator = 255.0; Color.Builder resultBuilder = Color .newBuilder() .setRed(red / denominator) .setGreen(green / denominator) .setBlue(blue / denominator); int alpha = color.getAlpha(); if (alpha != 255) { result.setAlpha( FloatValue .newBuilder() .setValue(((float) alpha) / denominator) .build()); } return resultBuilder.build(); } // ... Example (iOS / Obj-C): // ... static UIColor* fromProto(Color* protocolor) { float red = [protocolor red]; float green = [protocolor green]; float blue = [protocolor blue]; FloatValue* alpha_wrapper = [protocolor alpha]; float alpha = 1.0; if (alpha_wrapper != nil) { alpha = [alpha_wrapper value]; } return [UIColor colorWithRed:red green:green blue:blue alpha:alpha]; } static Color* toProto(UIColor* color) { CGFloat red, green, blue, alpha; if (![color getRed:&red green:&green blue:&blue alpha:&alpha]) { return nil; } Color* result = [[Color alloc] init]; [result setRed:red]; [result setGreen:green]; [result setBlue:blue]; if (alpha \u003c= 0.9999) { [result setAlpha:floatWrapperWithValue(alpha)]; } [result autorelease]; return result; } // ... Example (JavaScript): // ... var protoToCssColor = function(rgb_color) { var redFrac = rgb_color.red || 0.0; var greenFrac = rgb_color.green || 0.0; var blueFrac = rgb_color.blue || 0.0; var red = Math.floor(redFrac * 255); var green = Math.floor(greenFrac * 255); var blue = Math.floor(blueFrac * 255); if (!('alpha' in rgb_color)) { return rgbToCssColor(red, green, blue); } var alphaFrac = rgb_color.alpha.value || 0.0; var rgbParams = [red, green, blue].join(','); return ['rgba(', rgbParams, ',', alphaFrac, ')'].join(''); }; var rgbToCssColor = function(red, green, blue) { var rgbNumber = new Number((red \u003c\u003c 16) | (green \u003c\u003c 8) | blue); var hexString = rgbNumber.toString(16); var missingZeros = 6 - hexString.length; var resultBuilder = ['#']; for (var i = 0; i \u003c missingZeros; i++) { resultBuilder.push('0'); } resultBuilder.push(hexString); return resultBuilder.join(''); }; // ...",
      "id": "GoogleTypeColor",
      "type": "object"
    },
    "GoogleIamV1AuditConfig": {
      "properties": {
        "service": {
          "description": "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.",
          "type": "string"
        },
        "auditLogConfigs": {
          "description": "The configuration for logging of each type of permission.",
          "type": "array",
          "items": {
            "$ref": "GoogleIamV1AuditLogConfig"
          }
        }
      },
      "id": "GoogleIamV1AuditConfig",
      "type": "object",
      "description": "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."
    },
    "GoogleCloudContentwarehouseV1GcsIngestPipeline": {
      "description": "The configuration of the Cloud Storage Ingestion pipeline.",
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1GcsIngestPipeline",
      "properties": {
        "pipelineConfig": {
          "description": "Optional. The config for the Cloud Storage Ingestion pipeline. It provides additional customization options to run the pipeline and can be skipped if it is not applicable.",
          "$ref": "GoogleCloudContentwarehouseV1IngestPipelineConfig"
        },
        "inputPath": {
          "type": "string",
          "description": "The input Cloud Storage folder. All files under this folder will be imported to Document Warehouse. Format: `gs:///`."
        },
        "skipIngestedDocuments": {
          "description": "The flag whether to skip ingested documents. If it is set to true, documents in Cloud Storage contains key \"status\" with value \"status=ingested\" in custom metadata will be skipped to ingest.",
          "type": "boolean"
        },
        "processorType": {
          "type": "string",
          "description": "The Doc AI processor type name. Only used when the format of ingested files is Doc AI Document proto format."
        },
        "schemaName": {
          "description": "The Document Warehouse schema resource name. All documents processed by this pipeline will use this schema. Format: projects/{project_number}/locations/{location}/documentSchemas/{document_schema_id}.",
          "type": "string"
        }
      }
    },
    "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunkChunkPageHeader": {
      "type": "object",
      "properties": {
        "text": {
          "type": "string",
          "description": "Header in text format."
        },
        "pageSpan": {
          "description": "Page span of the header.",
          "$ref": "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunkChunkPageSpan"
        }
      },
      "description": "Represents the page header associated with the chunk.",
      "id": "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunkChunkPageHeader"
    },
    "GoogleCloudContentwarehouseV1SynonymSet": {
      "description": "Represents a list of synonyms for a given context. For example a context \"sales\" could contain: Synonym 1: sale, invoice, bill, order Synonym 2: money, credit, finance, payment Synonym 3: shipping, freight, transport Each SynonymSets should be disjoint",
      "properties": {
        "context": {
          "description": "This is a freeform field. Example contexts can be \"sales,\" \"engineering,\" \"real estate,\" \"accounting,\" etc. The context can be supplied during search requests.",
          "type": "string"
        },
        "name": {
          "type": "string",
          "description": "The resource name of the SynonymSet This is mandatory for google.api.resource. Format: projects/{project_number}/locations/{location}/synonymSets/{context}."
        },
        "synonyms": {
          "description": "List of Synonyms for the context.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1SynonymSetSynonym"
          }
        }
      },
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1SynonymSet"
    },
    "CloudAiPlatformTenantresourceInfraSpannerConfigCreateDatabaseOptions": {
      "id": "CloudAiPlatformTenantresourceInfraSpannerConfigCreateDatabaseOptions",
      "description": "The options to create a spanner database. KMS key access audit logging and AxT logging will be associated with the given resource name, resource type and service name. Please ensure to give right options to enable correct audit logging and AxT logging.",
      "properties": {
        "cmekCloudResourceName": {
          "type": "string",
          "description": "The cloud resource name for the CMEK encryption. For example, projects//locations/"
        },
        "cmekCloudResourceType": {
          "type": "string",
          "description": "The cloud resource type for the CMEK encryption. For example, contentwarehouse.googleapis.com/Location"
        },
        "cmekServiceName": {
          "type": "string",
          "description": "The service name for the CMEK encryption. For example, contentwarehouse.googleapis.com"
        }
      },
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1ListDocumentSchemasResponse": {
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1ListDocumentSchemasResponse",
      "description": "Response message for DocumentSchemaService.ListDocumentSchemas.",
      "properties": {
        "nextPageToken": {
          "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.",
          "type": "string"
        },
        "documentSchemas": {
          "description": "The document schemas from the specified parent.",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1DocumentSchema"
          },
          "type": "array"
        }
      }
    },
    "GoogleCloudContentwarehouseV1CustomWeightsMetadata": {
      "type": "object",
      "properties": {
        "weightedSchemaProperties": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1WeightedSchemaProperty"
          },
          "description": "List of schema and property name. Allows a maximum of 10 schemas to be specified for relevance boosting."
        }
      },
      "id": "GoogleCloudContentwarehouseV1CustomWeightsMetadata",
      "description": "To support the custom weighting across document schemas."
    },
    "GoogleCloudContentwarehouseV1PropertyDefinition": {
      "description": "Defines the metadata for a schema property.",
      "type": "object",
      "properties": {
        "enumTypeOptions": {
          "description": "Enum/categorical property.",
          "$ref": "GoogleCloudContentwarehouseV1EnumTypeOptions"
        },
        "name": {
          "type": "string",
          "description": "Required. The name of the metadata property. Must be unique within a document schema and is case insensitive. Names must be non-blank, start with a letter, and can contain alphanumeric characters and: /, :, -, _, and ."
        },
        "schemaSources": {
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1PropertyDefinitionSchemaSource"
          },
          "description": "The mapping information between this property to another schema source.",
          "type": "array"
        },
        "textTypeOptions": {
          "$ref": "GoogleCloudContentwarehouseV1TextTypeOptions",
          "description": "Text/string property."
        },
        "isRequired": {
          "description": "Whether the property is mandatory. Default is 'false', i.e. populating property value can be skipped. If 'true' then user must populate the value for this property.",
          "type": "boolean"
        },
        "isRepeatable": {
          "description": "Whether the property can have multiple values.",
          "type": "boolean"
        },
        "retrievalImportance": {
          "description": "The retrieval importance of the property during search.",
          "enumDescriptions": [
            "No importance specified. Default medium importance.",
            "Highest importance.",
            "Higher importance.",
            "High importance.",
            "Medium importance.",
            "Low importance (negative).",
            "Lowest importance (negative)."
          ],
          "enum": [
            "RETRIEVAL_IMPORTANCE_UNSPECIFIED",
            "HIGHEST",
            "HIGHER",
            "HIGH",
            "MEDIUM",
            "LOW",
            "LOWEST"
          ],
          "type": "string"
        },
        "isSearchable": {
          "description": "Indicates that the property should be included in a global search.",
          "type": "boolean"
        },
        "isMetadata": {
          "description": "Whether the property is user supplied metadata. This out-of-the box placeholder setting can be used to tag derived properties. Its value and interpretation logic should be implemented by API user.",
          "type": "boolean"
        },
        "dateTimeTypeOptions": {
          "description": "Date time property. It is not supported by CMEK compliant deployment.",
          "$ref": "GoogleCloudContentwarehouseV1DateTimeTypeOptions"
        },
        "mapTypeOptions": {
          "$ref": "GoogleCloudContentwarehouseV1MapTypeOptions",
          "description": "Map property."
        },
        "isFilterable": {
          "type": "boolean",
          "description": "Whether the property can be filtered. If this is a sub-property, all the parent properties must be marked filterable."
        },
        "floatTypeOptions": {
          "description": "Float property.",
          "$ref": "GoogleCloudContentwarehouseV1FloatTypeOptions"
        },
        "timestampTypeOptions": {
          "description": "Timestamp property. It is not supported by CMEK compliant deployment.",
          "$ref": "GoogleCloudContentwarehouseV1TimestampTypeOptions"
        },
        "displayName": {
          "type": "string",
          "description": "The display-name for the property, used for front-end."
        },
        "propertyTypeOptions": {
          "description": "Nested structured data property.",
          "$ref": "GoogleCloudContentwarehouseV1PropertyTypeOptions"
        },
        "integerTypeOptions": {
          "$ref": "GoogleCloudContentwarehouseV1IntegerTypeOptions",
          "description": "Integer property."
        }
      },
      "id": "GoogleCloudContentwarehouseV1PropertyDefinition"
    },
    "GoogleTypeTimeZone": {
      "type": "object",
      "id": "GoogleTypeTimeZone",
      "properties": {
        "id": {
          "type": "string",
          "description": "IANA Time Zone Database time zone. For example \"America/New_York\"."
        },
        "version": {
          "description": "Optional. IANA Time Zone Database version number. For example \"2019a\".",
          "type": "string"
        }
      },
      "description": "Represents a time zone from the [IANA Time Zone Database](https://www.iana.org/time-zones)."
    },
    "GoogleCloudDocumentaiV1DocumentPage": {
      "description": "A page in a Document.",
      "properties": {
        "paragraphs": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageParagraph"
          },
          "type": "array",
          "description": "A list of visually detected text paragraphs on the page. A collection of lines that a human would perceive as a paragraph."
        },
        "layout": {
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout",
          "description": "Layout for the page."
        },
        "detectedLanguages": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage"
          },
          "description": "A list of detected languages together with confidence."
        },
        "tables": {
          "description": "A list of visually detected tables on the page.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageTable"
          },
          "type": "array"
        },
        "transforms": {
          "description": "Transformation matrices that were applied to the original document image to produce Page.image.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageMatrix"
          },
          "type": "array"
        },
        "lines": {
          "description": "A list of visually detected text lines on the page. A collection of tokens that a human would perceive as a line.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageLine"
          },
          "type": "array"
        },
        "imageQualityScores": {
          "description": "Image quality scores.",
          "$ref": "GoogleCloudDocumentaiV1DocumentPageImageQualityScores"
        },
        "provenance": {
          "description": "The history of this page.",
          "deprecated": true,
          "$ref": "GoogleCloudDocumentaiV1DocumentProvenance"
        },
        "pageNumber": {
          "type": "integer",
          "format": "int32",
          "description": "1-based index for current Page in a parent Document. Useful when a page is taken out of a Document for individual processing."
        },
        "symbols": {
          "type": "array",
          "description": "A list of visually detected symbols on the page.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageSymbol"
          }
        },
        "detectedBarcodes": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedBarcode"
          },
          "description": "A list of detected barcodes."
        },
        "tokens": {
          "type": "array",
          "description": "A list of visually detected tokens on the page.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageToken"
          }
        },
        "dimension": {
          "$ref": "GoogleCloudDocumentaiV1DocumentPageDimension",
          "description": "Physical dimension of the page."
        },
        "visualElements": {
          "type": "array",
          "description": "A list of detected non-text visual elements e.g. checkbox, signature etc. on the page.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageVisualElement"
          }
        },
        "image": {
          "description": "Rendered image for this page. This image is preprocessed to remove any skew, rotation, and distortions such that the annotation bounding boxes can be upright and axis-aligned.",
          "$ref": "GoogleCloudDocumentaiV1DocumentPageImage"
        },
        "blocks": {
          "description": "A list of visually detected text blocks on the page. A block has a set of lines (collected into paragraphs) that have a common line-spacing and orientation.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageBlock"
          }
        },
        "formFields": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageFormField"
          },
          "description": "A list of visually detected form fields on the page.",
          "type": "array"
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentPage",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1RunPipelineRequest": {
      "type": "object",
      "description": "Request message for DocumentService.RunPipeline.",
      "id": "GoogleCloudContentwarehouseV1RunPipelineRequest",
      "properties": {
        "requestMetadata": {
          "$ref": "GoogleCloudContentwarehouseV1RequestMetadata",
          "description": "The meta information collected about the end user, used to enforce access control for the service."
        },
        "gcsIngestWithDocAiProcessorsPipeline": {
          "description": "Use DocAI processors to process documents in Cloud Storage and ingest them to Document Warehouse.",
          "$ref": "GoogleCloudContentwarehouseV1GcsIngestWithDocAiProcessorsPipeline"
        },
        "exportCdwPipeline": {
          "description": "Export docuemnts from Document Warehouse to CDW for training purpose.",
          "$ref": "GoogleCloudContentwarehouseV1ExportToCdwPipeline"
        },
        "processWithDocAiPipeline": {
          "$ref": "GoogleCloudContentwarehouseV1ProcessWithDocAiPipeline",
          "description": "Use a DocAI processor to process documents in Document Warehouse, and re-ingest the updated results into Document Warehouse."
        },
        "gcsIngestPipeline": {
          "$ref": "GoogleCloudContentwarehouseV1GcsIngestPipeline",
          "description": "Cloud Storage ingestion pipeline."
        }
      }
    },
    "GoogleCloudContentwarehouseV1RunPipelineMetadataIndividualDocumentStatus": {
      "properties": {
        "documentId": {
          "type": "string",
          "description": "Document identifier of an existing document."
        },
        "status": {
          "$ref": "GoogleRpcStatus",
          "description": "The status processing the document."
        }
      },
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1RunPipelineMetadataIndividualDocumentStatus",
      "description": "The status of processing a document."
    },
    "GoogleCloudContentwarehouseV1GetDocumentRequest": {
      "properties": {
        "requestMetadata": {
          "$ref": "GoogleCloudContentwarehouseV1RequestMetadata",
          "description": "The meta information collected about the end user, used to enforce access control for the service."
        }
      },
      "type": "object",
      "description": "Request message for DocumentService.GetDocument.",
      "id": "GoogleCloudContentwarehouseV1GetDocumentRequest"
    },
    "GoogleCloudContentwarehouseV1RuleActionsPair": {
      "properties": {
        "actionOutputs": {
          "description": "Outputs of executing the actions associated with the above rule.",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1ActionOutput"
          },
          "type": "array"
        },
        "rule": {
          "$ref": "GoogleCloudContentwarehouseV1Rule",
          "description": "Represents the rule."
        }
      },
      "description": "Represents a rule and outputs of associated actions.",
      "id": "GoogleCloudContentwarehouseV1RuleActionsPair",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1SearchDocumentsRequest": {
      "id": "GoogleCloudContentwarehouseV1SearchDocumentsRequest",
      "properties": {
        "orderBy": {
          "description": "The criteria determining how search results are sorted. For non-empty query, default is `\"relevance desc\"`. For empty query, default is `\"upload_date desc\"`. Supported options are: * `\"relevance desc\"`: By relevance descending, as determined by the API algorithms. * `\"upload_date desc\"`: By upload date descending. * `\"upload_date\"`: By upload date ascending. * `\"update_date desc\"`: By last updated date descending. * `\"update_date\"`: By last updated date ascending. * `\"retrieval_importance desc\"`: By retrieval importance of properties descending. This feature is still under development, please do not use unless otherwise instructed to do so.",
          "type": "string"
        },
        "qaSizeLimit": {
          "description": "Experimental, do not use. The limit on the number of documents returned for the question-answering feature. To enable the question-answering feature, set [DocumentQuery].is_nl_query to true.",
          "format": "int32",
          "type": "integer"
        },
        "histogramQueries": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1HistogramQuery"
          },
          "description": "An expression specifying a histogram request against matching documents. Expression syntax is an aggregation function call with histogram facets and other options. The following aggregation functions are supported: * `count(string_histogram_facet)`: Count the number of matching entities for each distinct attribute value. Data types: * Histogram facet (aka filterable properties): Facet names with format \u003cschema id\u003e.\u003cfacet\u003e. Facets will have the format of: `a-zA-Z`. If the facet is a child facet, then the parent hierarchy needs to be specified separated by dots in the prefix after the schema id. Thus, the format for a multi- level facet is: \u003cschema id\u003e.\u003cparent facet name\u003e. \u003cchild facet name\u003e. Example: schema123.root_parent_facet.middle_facet.child_facet * DocumentSchemaId: (with no schema id prefix) to get histograms for each document type (returns the schema id path, e.g. projects/12345/locations/us-west/documentSchemas/abc123). Example expression: * Document type counts: count('DocumentSchemaId') * For schema id, abc123, get the counts for MORTGAGE_TYPE: count('abc123.MORTGAGE_TYPE')"
        },
        "requireTotalSize": {
          "description": "Controls if the search document request requires the return of a total size of matched documents. See SearchDocumentsResponse.total_size. Enabling this flag may adversely impact performance. Hint: If this is used with pagination, set this flag on the initial query but set this to false on subsequent page calls (keep the total count locally). Defaults to false.",
          "type": "boolean"
        },
        "totalResultSize": {
          "enumDescriptions": [
            "Total number calculation will be skipped.",
            "Estimate total number. The total result size will be accurated up to 10,000. This option will add cost and latency to your request.",
            "It may adversely impact performance. The limit is 1000,000."
          ],
          "description": "Controls if the search document request requires the return of a total size of matched documents. See SearchDocumentsResponse.total_size.",
          "enum": [
            "TOTAL_RESULT_SIZE_UNSPECIFIED",
            "ESTIMATED_SIZE",
            "ACTUAL_SIZE"
          ],
          "type": "string"
        },
        "documentQuery": {
          "description": "Query used to search against documents (keyword, filters, etc.).",
          "$ref": "GoogleCloudContentwarehouseV1DocumentQuery"
        },
        "pageToken": {
          "type": "string",
          "description": "The token specifying the current offset within search results. See SearchDocumentsResponse.next_page_token for an explanation of how to obtain the next set of query results."
        },
        "offset": {
          "description": "An integer that specifies the current offset (that is, starting result location, amongst the documents deemed by the API as relevant) in search results. This field is only considered if page_token is unset. The maximum allowed value is 5000. Otherwise an error is thrown. For example, 0 means to return results starting from the first matching document, and 10 means to return from the 11th document. This can be used for pagination, (for example, pageSize = 10 and offset = 10 means to return from the second page).",
          "format": "int32",
          "type": "integer"
        },
        "requestMetadata": {
          "description": "The meta information collected about the end user, used to enforce access control and improve the search quality of the service.",
          "$ref": "GoogleCloudContentwarehouseV1RequestMetadata"
        },
        "pageSize": {
          "format": "int32",
          "type": "integer",
          "description": "A limit on the number of documents returned in the search results. Increasing this value above the default value of 10 can increase search response time. The value can be between 1 and 100."
        }
      },
      "description": "Request message for DocumentService.SearchDocuments.",
      "type": "object"
    },
    "GoogleCloudDocumentaiV1DocumentDocumentLayout": {
      "description": "Represents the parsed layout of a document as a collection of blocks that the document is divided into.",
      "properties": {
        "blocks": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlock"
          },
          "description": "List of blocks in the document."
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentDocumentLayout",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1GcsIngestWithDocAiProcessorsPipeline": {
      "type": "object",
      "description": "The configuration of the Cloud Storage Ingestion with DocAI Processors pipeline.",
      "id": "GoogleCloudContentwarehouseV1GcsIngestWithDocAiProcessorsPipeline",
      "properties": {
        "extractProcessorInfos": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1ProcessorInfo"
          },
          "description": "The extract processors information. One matched extract processor will be used to process documents based on the classify processor result. If no classify processor is specified, the first extract processor will be used."
        },
        "skipIngestedDocuments": {
          "type": "boolean",
          "description": "The flag whether to skip ingested documents. If it is set to true, documents in Cloud Storage contains key \"status\" with value \"status=ingested\" in custom metadata will be skipped to ingest."
        },
        "processorResultsFolderPath": {
          "type": "string",
          "description": "The Cloud Storage folder path used to store the raw results from processors. Format: `gs:///`."
        },
        "pipelineConfig": {
          "description": "Optional. The config for the Cloud Storage Ingestion with DocAI Processors pipeline. It provides additional customization options to run the pipeline and can be skipped if it is not applicable.",
          "$ref": "GoogleCloudContentwarehouseV1IngestPipelineConfig"
        },
        "splitClassifyProcessorInfo": {
          "description": "The split and classify processor information. The split and classify result will be used to find a matched extract processor.",
          "$ref": "GoogleCloudContentwarehouseV1ProcessorInfo"
        },
        "inputPath": {
          "type": "string",
          "description": "The input Cloud Storage folder. All files under this folder will be imported to Document Warehouse. Format: `gs:///`."
        }
      }
    },
    "GoogleCloudContentwarehouseV1CreateDocumentRequest": {
      "properties": {
        "document": {
          "description": "Required. The document to create.",
          "$ref": "GoogleCloudContentwarehouseV1Document"
        },
        "policy": {
          "$ref": "GoogleIamV1Policy",
          "description": "Default document policy during creation. This refers to an Identity and Access (IAM) policy, which specifies access controls for the Document. Conditions defined in the policy will be ignored."
        },
        "requestMetadata": {
          "description": "The meta information collected about the end user, used to enforce access control for the service.",
          "$ref": "GoogleCloudContentwarehouseV1RequestMetadata"
        },
        "cloudAiDocumentOption": {
          "description": "Request Option for processing Cloud AI Document in Document Warehouse. This field offers limited support for mapping entities from Cloud AI Document to Warehouse Document. Please consult with product team before using this field and other available options.",
          "$ref": "GoogleCloudContentwarehouseV1CloudAIDocumentOption"
        },
        "createMask": {
          "description": "Field mask for creating Document fields. If mask path is empty, it means all fields are masked. For the `FieldMask` definition, see https://developers.google.com/protocol-buffers/docs/reference/google.protobuf#fieldmask.",
          "type": "string",
          "format": "google-fieldmask"
        }
      },
      "description": "Request message for DocumentService.CreateDocument.",
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1CreateDocumentRequest"
    },
    "GoogleCloudDocumentaiV1DocumentPageSymbol": {
      "description": "A detected symbol.",
      "properties": {
        "layout": {
          "description": "Layout for Symbol.",
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout"
        },
        "detectedLanguages": {
          "description": "A list of detected languages together with confidence.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage"
          },
          "type": "array"
        }
      },
      "type": "object",
      "id": "GoogleCloudDocumentaiV1DocumentPageSymbol"
    },
    "GoogleCloudContentwarehouseV1ListLinkedTargetsResponse": {
      "properties": {
        "nextPageToken": {
          "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.",
          "type": "string"
        },
        "documentLinks": {
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1DocumentLink"
          },
          "description": "Target document-links.",
          "type": "array"
        }
      },
      "description": "Response message for DocumentLinkService.ListLinkedTargets.",
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1ListLinkedTargetsResponse"
    },
    "GoogleCloudContentwarehouseV1ResponseMetadata": {
      "properties": {
        "requestId": {
          "type": "string",
          "description": "A unique id associated with this call. This id is logged for tracking purpose."
        }
      },
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1ResponseMetadata",
      "description": "Additional information returned to client, such as debugging information."
    },
    "GoogleCloudContentwarehouseV1ListRuleSetsResponse": {
      "properties": {
        "nextPageToken": {
          "type": "string",
          "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages."
        },
        "ruleSets": {
          "description": "The rule sets from the specified parent.",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1RuleSet"
          },
          "type": "array"
        }
      },
      "type": "object",
      "description": "Response message for RuleSetService.ListRuleSets.",
      "id": "GoogleCloudContentwarehouseV1ListRuleSetsResponse"
    },
    "GoogleCloudDocumentaiV1DocumentShardInfo": {
      "description": "For a large document, sharding may be performed to produce several document shards. Each document shard contains this field to detail which shard it is.",
      "type": "object",
      "properties": {
        "shardIndex": {
          "format": "int64",
          "description": "The 0-based index of this shard.",
          "type": "string"
        },
        "shardCount": {
          "description": "Total number of shards.",
          "format": "int64",
          "type": "string"
        },
        "textOffset": {
          "format": "int64",
          "type": "string",
          "description": "The index of the first character in Document.text in the overall document global text."
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentShardInfo"
    },
    "GoogleCloudContentwarehouseV1TimestampArray": {
      "description": "Timestamp values.",
      "type": "object",
      "properties": {
        "values": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1TimestampValue"
          },
          "description": "List of timestamp values."
        }
      },
      "id": "GoogleCloudContentwarehouseV1TimestampArray"
    },
    "GoogleCloudContentwarehouseV1QAResultHighlight": {
      "properties": {
        "startIndex": {
          "description": "Start index of the highlight.",
          "type": "integer",
          "format": "int32"
        },
        "endIndex": {
          "type": "integer",
          "format": "int32",
          "description": "End index of the highlight, exclusive."
        }
      },
      "id": "GoogleCloudContentwarehouseV1QAResultHighlight",
      "type": "object",
      "description": "A text span in the search text snippet that represents a highlighted section (answer context, highly relevant sentence, etc.)."
    },
    "GoogleCloudDocumentaiV1BoundingPoly": {
      "description": "A bounding polygon for the detected image annotation.",
      "type": "object",
      "id": "GoogleCloudDocumentaiV1BoundingPoly",
      "properties": {
        "normalizedVertices": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1NormalizedVertex"
          },
          "description": "The bounding polygon normalized vertices."
        },
        "vertices": {
          "type": "array",
          "description": "The bounding polygon vertices.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1Vertex"
          }
        }
      }
    },
    "GoogleCloudContentwarehouseV1RunPipelineMetadataExportToCdwPipelineMetadata": {
      "description": "The metadata message for Export-to-CDW pipeline.",
      "id": "GoogleCloudContentwarehouseV1RunPipelineMetadataExportToCdwPipelineMetadata",
      "properties": {
        "docAiDataset": {
          "type": "string",
          "description": "The output CDW dataset resource name."
        },
        "outputPath": {
          "description": "The output Cloud Storage folder in this pipeline.",
          "type": "string"
        },
        "documents": {
          "type": "array",
          "description": "The input list of all the resource names of the documents to be exported.",
          "items": {
            "type": "string"
          }
        }
      },
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1TextTypeOptions": {
      "id": "GoogleCloudContentwarehouseV1TextTypeOptions",
      "description": "Configurations for a text property.",
      "type": "object",
      "properties": {}
    },
    "CloudAiPlatformTenantresourceCloudSqlInstanceConfig": {
      "type": "object",
      "id": "CloudAiPlatformTenantresourceCloudSqlInstanceConfig",
      "properties": {
        "cloudSqlInstanceConnectionName": {
          "type": "string",
          "description": "Output only. The CloudSQL instance connection name."
        },
        "slmInstanceTemplate": {
          "type": "string",
          "description": "Input [Required]. The SLM instance template to provision CloudSQL."
        },
        "kmsKeyReference": {
          "description": "Input [Optional]. The KMS key name or the KMS grant name used for CMEK encryption. Only set this field when provisioning new CloudSQL instances. For existing CloudSQL instances, this field will be ignored because CMEK re-encryption is not supported.",
          "type": "string"
        },
        "slmInstanceType": {
          "description": "Input [Required]. The SLM instance type to provision CloudSQL.",
          "type": "string"
        },
        "slmInstanceName": {
          "description": "Output only. The SLM instance's full resource name.",
          "type": "string"
        },
        "cloudSqlInstanceName": {
          "type": "string",
          "description": "Input/Output [Optional]. The CloudSQL instance name within SLM instance. If not set, a random UUIC will be generated as instance name."
        },
        "mdbRolesForCorpAccess": {
          "items": {
            "type": "string"
          },
          "description": "Input [Optional]. MDB roles for corp access to CloudSQL instance.",
          "type": "array"
        }
      },
      "description": "The identity to configure a CloudSQL instance provisioned via SLM Terraform."
    },
    "GoogleCloudContentwarehouseV1CreateDocumentMetadata": {
      "properties": {},
      "id": "GoogleCloudContentwarehouseV1CreateDocumentMetadata",
      "description": "Metadata object for CreateDocument request (currently empty).",
      "type": "object"
    },
    "GoogleCloudDocumentaiV1DocumentPageImageQualityScoresDetectedDefect": {
      "id": "GoogleCloudDocumentaiV1DocumentPageImageQualityScoresDetectedDefect",
      "properties": {
        "confidence": {
          "format": "float",
          "type": "number",
          "description": "Confidence of detected defect. Range `[0, 1]` where `1` indicates strong confidence that the defect exists."
        },
        "type": {
          "description": "Name of the defect type. Supported values are: - `quality/defect_blurry` - `quality/defect_noisy` - `quality/defect_dark` - `quality/defect_faint` - `quality/defect_text_too_small` - `quality/defect_document_cutoff` - `quality/defect_text_cutoff` - `quality/defect_glare`",
          "type": "string"
        }
      },
      "type": "object",
      "description": "Image Quality Defects"
    },
    "GoogleCloudContentwarehouseV1EnumTypeOptions": {
      "properties": {
        "possibleValues": {
          "description": "Required. List of possible enum values.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "validationCheckDisabled": {
          "description": "Make sure the Enum property value provided in the document is in the possile value list during document creation. The validation check runs by default.",
          "type": "boolean"
        }
      },
      "description": "Configurations for an enum/categorical property.",
      "id": "GoogleCloudContentwarehouseV1EnumTypeOptions",
      "type": "object"
    },
    "GoogleCloudDocumentaiV1Vertex": {
      "id": "GoogleCloudDocumentaiV1Vertex",
      "description": "A vertex represents a 2D point in the image. NOTE: the vertex coordinates are in the same scale as the original image.",
      "type": "object",
      "properties": {
        "x": {
          "description": "X coordinate.",
          "type": "integer",
          "format": "int32"
        },
        "y": {
          "description": "Y coordinate (starts from the top of the image).",
          "format": "int32",
          "type": "integer"
        }
      }
    },
    "GoogleCloudContentwarehouseV1UserInfo": {
      "id": "GoogleCloudContentwarehouseV1UserInfo",
      "properties": {
        "id": {
          "description": "A unique user identification string, as determined by the client. The maximum number of allowed characters is 255. Allowed characters include numbers 0 to 9, uppercase and lowercase letters, and restricted special symbols (:, @, +, -, _, ~) The format is \"user:xxxx@example.com\";",
          "type": "string"
        },
        "groupIds": {
          "type": "array",
          "description": "The unique group identifications which the user is belong to. The format is \"group:yyyy@example.com\";",
          "items": {
            "type": "string"
          }
        }
      },
      "description": "The user information.",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1RuleSet": {
      "properties": {
        "source": {
          "description": "Source of the rules i.e., customer name.",
          "type": "string"
        },
        "description": {
          "type": "string",
          "description": "Short description of the rule-set."
        },
        "rules": {
          "type": "array",
          "description": "List of rules given by the customer.",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1Rule"
          }
        },
        "name": {
          "type": "string",
          "description": "The resource name of the rule set. Managed internally. Format: projects/{project_number}/locations/{location}/ruleSet/{rule_set_id}. The name is ignored when creating a rule set."
        }
      },
      "id": "GoogleCloudContentwarehouseV1RuleSet",
      "type": "object",
      "description": "Represents a set of rules from a single customer."
    },
    "GoogleCloudContentwarehouseV1DocumentSchema": {
      "properties": {
        "description": {
          "description": "Schema description.",
          "type": "string"
        },
        "displayName": {
          "description": "Required. Name of the schema given by the user. Must be unique per project.",
          "type": "string"
        },
        "propertyDefinitions": {
          "description": "Document details.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1PropertyDefinition"
          }
        },
        "documentIsFolder": {
          "description": "Document Type, true refers the document is a folder, otherwise it is a typical document.",
          "type": "boolean"
        },
        "name": {
          "description": "The resource name of the document schema. Format: projects/{project_number}/locations/{location}/documentSchemas/{document_schema_id}. The name is ignored when creating a document schema.",
          "type": "string"
        },
        "createTime": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The time when the document schema is created.",
          "format": "google-datetime"
        },
        "updateTime": {
          "type": "string",
          "readOnly": true,
          "description": "Output only. The time when the document schema is last updated.",
          "format": "google-datetime"
        }
      },
      "id": "GoogleCloudContentwarehouseV1DocumentSchema",
      "type": "object",
      "description": "A document schema used to define document structure."
    },
    "GoogleCloudContentwarehouseV1DeleteDocumentAction": {
      "id": "GoogleCloudContentwarehouseV1DeleteDocumentAction",
      "description": "Represents the action responsible for deleting the document.",
      "properties": {
        "enableHardDelete": {
          "type": "boolean",
          "description": "Boolean field to select between hard vs soft delete options. Set 'true' for 'hard delete' and 'false' for 'soft delete'."
        }
      },
      "type": "object"
    },
    "CloudAiPlatformTenantresourceTenantServiceAccountIdentity": {
      "properties": {
        "serviceName": {
          "type": "string",
          "description": "Input/Output [Required]. The service that the service account belongs to. (e.g. cloudbuild.googleapis.com for GCB service accounts)"
        },
        "serviceAccountEmail": {
          "description": "Output only. The email address of the generated service account.",
          "type": "string"
        }
      },
      "description": "The identity of service accounts that have been explicitly created under tenant projects.",
      "type": "object",
      "id": "CloudAiPlatformTenantresourceTenantServiceAccountIdentity"
    },
    "GoogleCloudContentwarehouseV1SearchDocumentsResponse": {
      "properties": {
        "nextPageToken": {
          "description": "The token that specifies the starting position of the next page of results. This field is empty if there are no more results.",
          "type": "string"
        },
        "metadata": {
          "description": "Additional information for the API invocation, such as the request tracking id.",
          "$ref": "GoogleCloudContentwarehouseV1ResponseMetadata"
        },
        "matchingDocuments": {
          "description": "The document entities that match the specified SearchDocumentsRequest.",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1SearchDocumentsResponseMatchingDocument"
          },
          "type": "array"
        },
        "totalSize": {
          "format": "int32",
          "type": "integer",
          "description": "The total number of matched documents which is available only if the client set SearchDocumentsRequest.require_total_size to `true` or set SearchDocumentsRequest.total_result_size to `ESTIMATED_SIZE` or `ACTUAL_SIZE`. Otherwise, the value will be `-1`. Typically a UI would handle this condition by displaying \"of many\", for example: \"Displaying 10 of many\"."
        },
        "questionAnswer": {
          "description": "Experimental. Question answer from the query against the document.",
          "type": "string"
        },
        "histogramQueryResults": {
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1HistogramQueryResult"
          },
          "description": "The histogram results that match with the specified SearchDocumentsRequest.histogram_queries.",
          "type": "array"
        }
      },
      "description": "Response message for DocumentService.SearchDocuments.",
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1SearchDocumentsResponse"
    },
    "CloudAiPlatformTenantresourceTenantProjectConfig": {
      "type": "object",
      "id": "CloudAiPlatformTenantresourceTenantProjectConfig",
      "description": "The identity to configure a tenant project.",
      "properties": {
        "services": {
          "items": {
            "type": "string"
          },
          "type": "array",
          "description": "Input/Output [Required]. The API services that are enabled on the tenant project during creation."
        },
        "folder": {
          "type": "string",
          "description": "Input/Output [Required]. The folder that holds tenant projects and folder-level permissions will be automatically granted to all tenant projects under the folder. Note: the valid folder format is `folders/{folder_number}`."
        },
        "policyBindings": {
          "type": "array",
          "items": {
            "$ref": "GoogleApiServiceconsumermanagementV1PolicyBinding"
          },
          "description": "Input/Output [Required]. The policy bindings that are applied to the tenant project during creation. At least one binding must have the role `roles/owner` with either `user` or `group` type."
        },
        "billingConfig": {
          "description": "Input/Output [Required]. The billing account properties to create the tenant project.",
          "$ref": "GoogleApiServiceconsumermanagementV1BillingConfig"
        }
      }
    },
    "GoogleCloudContentwarehouseV1beta1UpdateDocumentMetadata": {
      "type": "object",
      "description": "Metadata object for UpdateDocument request (currently empty).",
      "id": "GoogleCloudContentwarehouseV1beta1UpdateDocumentMetadata",
      "properties": {}
    },
    "GoogleCloudContentwarehouseV1HistogramQuery": {
      "id": "GoogleCloudContentwarehouseV1HistogramQuery",
      "description": "The histogram request.",
      "properties": {
        "histogramQuery": {
          "description": "An expression specifies a histogram request against matching documents for searches. See SearchDocumentsRequest.histogram_queries for details about syntax.",
          "type": "string"
        },
        "requirePreciseResultSize": {
          "description": "Controls if the histogram query requires the return of a precise count. Enable this flag may adversely impact performance. Defaults to true.",
          "type": "boolean"
        },
        "filters": {
          "description": "Optional. Filter the result of histogram query by the property names. It only works with histogram query count('FilterableProperties'). It is an optional. It will perform histogram on all the property names for all the document schemas. Setting this field will have a better performance.",
          "$ref": "GoogleCloudContentwarehouseV1HistogramQueryPropertyNameFilter"
        }
      },
      "type": "object"
    },
    "GoogleCloudDocumentaiV1DocumentEntity": {
      "properties": {
        "mentionText": {
          "description": "Optional. Text value of the entity e.g. `1600 Amphitheatre Pkwy`.",
          "type": "string"
        },
        "properties": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentEntity"
          },
          "description": "Optional. Entities can be nested to form a hierarchical data structure representing the content in the document.",
          "type": "array"
        },
        "confidence": {
          "description": "Optional. Confidence of detected Schema entity. Range `[0, 1]`.",
          "format": "float",
          "type": "number"
        },
        "id": {
          "type": "string",
          "description": "Optional. Canonical id. This will be a unique value in the entity list for this document."
        },
        "mentionId": {
          "description": "Optional. Deprecated. Use `id` field instead.",
          "type": "string"
        },
        "pageAnchor": {
          "description": "Optional. Represents the provenance of this entity wrt. the location on the page where it was found.",
          "$ref": "GoogleCloudDocumentaiV1DocumentPageAnchor"
        },
        "normalizedValue": {
          "description": "Optional. Normalized entity value. Absent if the extracted value could not be converted or the type (e.g. address) is not supported for certain parsers. This field is also only populated for certain supported document types.",
          "$ref": "GoogleCloudDocumentaiV1DocumentEntityNormalizedValue"
        },
        "redacted": {
          "description": "Optional. Whether the entity will be redacted for de-identification purposes.",
          "type": "boolean"
        },
        "textAnchor": {
          "$ref": "GoogleCloudDocumentaiV1DocumentTextAnchor",
          "description": "Optional. Provenance of the entity. Text anchor indexing into the Document.text."
        },
        "type": {
          "type": "string",
          "description": "Required. Entity type from a schema e.g. `Address`."
        },
        "provenance": {
          "description": "Optional. The history of this annotation.",
          "$ref": "GoogleCloudDocumentaiV1DocumentProvenance"
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentEntity",
      "description": "An entity that could be a phrase in the text or a property that belongs to the document. It is a known entity type, such as a person, an organization, or location.",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1PropertyDefinitionSchemaSource": {
      "description": "The schema source information.",
      "id": "GoogleCloudContentwarehouseV1PropertyDefinitionSchemaSource",
      "type": "object",
      "properties": {
        "processorType": {
          "type": "string",
          "description": "The Doc AI processor type name."
        },
        "name": {
          "description": "The schema name in the source.",
          "type": "string"
        }
      }
    },
    "GoogleCloudContentwarehouseV1TextArray": {
      "properties": {
        "values": {
          "type": "array",
          "description": "List of text values.",
          "items": {
            "type": "string"
          }
        }
      },
      "type": "object",
      "description": "String/text values.",
      "id": "GoogleCloudContentwarehouseV1TextArray"
    },
    "GoogleCloudDocumentaiV1DocumentPageTokenStyleInfo": {
      "properties": {
        "underlined": {
          "description": "Whether the text is underlined.",
          "type": "boolean"
        },
        "letterSpacing": {
          "description": "Letter spacing in points.",
          "format": "double",
          "type": "number"
        },
        "superscript": {
          "type": "boolean",
          "description": "Whether the text is a superscript. This feature is not supported yet."
        },
        "handwritten": {
          "description": "Whether the text is handwritten.",
          "type": "boolean"
        },
        "smallcaps": {
          "type": "boolean",
          "description": "Whether the text is in small caps. This feature is not supported yet."
        },
        "textColor": {
          "description": "Color of the text.",
          "$ref": "GoogleTypeColor"
        },
        "pixelFontSize": {
          "format": "double",
          "type": "number",
          "description": "Font size in pixels, equal to _unrounded font_size_ * _resolution_ ÷ `72.0`."
        },
        "fontWeight": {
          "type": "integer",
          "description": "TrueType weight on a scale `100` (thin) to `1000` (ultra-heavy). Normal is `400`, bold is `700`.",
          "format": "int32"
        },
        "fontType": {
          "description": "Name or style of the font.",
          "type": "string"
        },
        "italic": {
          "description": "Whether the text is italic.",
          "type": "boolean"
        },
        "bold": {
          "description": "Whether the text is bold (equivalent to font_weight is at least `700`).",
          "type": "boolean"
        },
        "subscript": {
          "type": "boolean",
          "description": "Whether the text is a subscript. This feature is not supported yet."
        },
        "backgroundColor": {
          "description": "Color of the background.",
          "$ref": "GoogleTypeColor"
        },
        "strikeout": {
          "description": "Whether the text is strikethrough. This feature is not supported yet.",
          "type": "boolean"
        },
        "fontSize": {
          "type": "integer",
          "description": "Font size in points (`1` point is `¹⁄₇₂` inches).",
          "format": "int32"
        }
      },
      "description": "Font and other text style attributes.",
      "type": "object",
      "id": "GoogleCloudDocumentaiV1DocumentPageTokenStyleInfo"
    },
    "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTableRow": {
      "properties": {
        "cells": {
          "type": "array",
          "description": "A table row is a list of table cells.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTableCell"
          }
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTableRow",
      "type": "object",
      "description": "Represents a row in a table."
    },
    "GoogleCloudContentwarehouseV1beta1CreateDocumentMetadata": {
      "id": "GoogleCloudContentwarehouseV1beta1CreateDocumentMetadata",
      "type": "object",
      "description": "Metadata object for CreateDocument request (currently empty).",
      "properties": {}
    },
    "GoogleCloudContentwarehouseV1MapProperty": {
      "id": "GoogleCloudContentwarehouseV1MapProperty",
      "description": "Map property value. Represents a structured entries of key value pairs, consisting of field names which map to dynamically typed values.",
      "type": "object",
      "properties": {
        "fields": {
          "type": "object",
          "description": "Unordered map of dynamically typed values.",
          "additionalProperties": {
            "$ref": "GoogleCloudContentwarehouseV1Value"
          }
        }
      }
    },
    "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTableBlock": {
      "type": "object",
      "id": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTableBlock",
      "properties": {
        "bodyRows": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTableRow"
          },
          "type": "array",
          "description": "Body rows containing main table content."
        },
        "headerRows": {
          "description": "Header rows at the top of the table.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTableRow"
          },
          "type": "array"
        },
        "caption": {
          "type": "string",
          "description": "Table caption/title."
        }
      },
      "description": "Represents a table type block."
    },
    "GoogleCloudDocumentaiV1DocumentTextChange": {
      "properties": {
        "provenance": {
          "type": "array",
          "deprecated": true,
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentProvenance"
          },
          "description": "The history of this annotation."
        },
        "textAnchor": {
          "description": "Provenance of the correction. Text anchor indexing into the Document.text. There can only be a single `TextAnchor.text_segments` element. If the start and end index of the text segment are the same, the text change is inserted before that index.",
          "$ref": "GoogleCloudDocumentaiV1DocumentTextAnchor"
        },
        "changedText": {
          "description": "The text that replaces the text identified in the `text_anchor`.",
          "type": "string"
        }
      },
      "type": "object",
      "id": "GoogleCloudDocumentaiV1DocumentTextChange",
      "description": "This message is used for text changes aka. OCR corrections."
    },
    "GoogleCloudContentwarehouseV1CreateDocumentLinkRequest": {
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1CreateDocumentLinkRequest",
      "properties": {
        "documentLink": {
          "$ref": "GoogleCloudContentwarehouseV1DocumentLink",
          "description": "Required. Document links associated with the source documents (source_document_id)."
        },
        "requestMetadata": {
          "$ref": "GoogleCloudContentwarehouseV1RequestMetadata",
          "description": "The meta information collected about the document creator, used to enforce access control for the service."
        }
      },
      "description": "Request message for DocumentLinkService.CreateDocumentLink."
    },
    "GoogleCloudDocumentaiV1DocumentPageDimension": {
      "properties": {
        "unit": {
          "description": "Dimension unit.",
          "type": "string"
        },
        "width": {
          "description": "Page width.",
          "type": "number",
          "format": "float"
        },
        "height": {
          "format": "float",
          "description": "Page height.",
          "type": "number"
        }
      },
      "description": "Dimension for the page.",
      "type": "object",
      "id": "GoogleCloudDocumentaiV1DocumentPageDimension"
    },
    "GoogleCloudContentwarehouseV1RunPipelineMetadata": {
      "description": "Metadata message of RunPipeline method.",
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1RunPipelineMetadata",
      "properties": {
        "totalFileCount": {
          "type": "integer",
          "description": "Number of files that were processed by the pipeline.",
          "format": "int32"
        },
        "gcsIngestPipelineMetadata": {
          "$ref": "GoogleCloudContentwarehouseV1RunPipelineMetadataGcsIngestPipelineMetadata",
          "description": "The pipeline metadata for GcsIngest pipeline."
        },
        "exportToCdwPipelineMetadata": {
          "description": "The pipeline metadata for Export-to-CDW pipeline.",
          "$ref": "GoogleCloudContentwarehouseV1RunPipelineMetadataExportToCdwPipelineMetadata"
        },
        "processWithDocAiPipelineMetadata": {
          "description": "The pipeline metadata for Process-with-DocAi pipeline.",
          "$ref": "GoogleCloudContentwarehouseV1RunPipelineMetadataProcessWithDocAiPipelineMetadata"
        },
        "individualDocumentStatuses": {
          "description": "The list of response details of each document.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1RunPipelineMetadataIndividualDocumentStatus"
          }
        },
        "failedFileCount": {
          "description": "Number of files that have failed at some point in the pipeline.",
          "type": "integer",
          "format": "int32"
        },
        "userInfo": {
          "$ref": "GoogleCloudContentwarehouseV1UserInfo",
          "description": "User unique identification and groups information."
        }
      }
    },
    "GoogleCloudContentwarehouseV1Action": {
      "description": "Represents the action triggered by Rule Engine when the rule is true.",
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1Action",
      "properties": {
        "removeFromFolderAction": {
          "description": "Action removing a document from a folder.",
          "$ref": "GoogleCloudContentwarehouseV1RemoveFromFolderAction"
        },
        "accessControl": {
          "description": "Action triggering access control operations.",
          "$ref": "GoogleCloudContentwarehouseV1AccessControlAction"
        },
        "publishToPubSub": {
          "$ref": "GoogleCloudContentwarehouseV1PublishAction",
          "description": "Action publish to Pub/Sub operation."
        },
        "addToFolder": {
          "$ref": "GoogleCloudContentwarehouseV1AddToFolderAction",
          "description": "Action triggering create document link operation."
        },
        "dataUpdate": {
          "description": "Action triggering data update operations.",
          "$ref": "GoogleCloudContentwarehouseV1DataUpdateAction"
        },
        "actionId": {
          "description": "ID of the action. Managed internally.",
          "type": "string"
        },
        "deleteDocumentAction": {
          "description": "Action deleting the document.",
          "$ref": "GoogleCloudContentwarehouseV1DeleteDocumentAction"
        },
        "dataValidation": {
          "$ref": "GoogleCloudContentwarehouseV1DataValidationAction",
          "description": "Action triggering data validation operations."
        }
      }
    },
    "GoogleRpcStatus": {
      "description": "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).",
      "id": "GoogleRpcStatus",
      "type": "object",
      "properties": {
        "message": {
          "description": "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.",
          "type": "string"
        },
        "code": {
          "format": "int32",
          "description": "The status code, which should be an enum value of google.rpc.Code.",
          "type": "integer"
        },
        "details": {
          "items": {
            "type": "object",
            "additionalProperties": {
              "description": "Properties of the object. Contains field @type with type URL.",
              "type": "any"
            }
          },
          "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use.",
          "type": "array"
        }
      }
    },
    "CloudAiPlatformTenantresourceInfraSpannerConfig": {
      "description": "The configuration for a spanner database provisioning. Next ID: 8",
      "id": "CloudAiPlatformTenantresourceInfraSpannerConfig",
      "properties": {
        "spannerBorgServiceAccount": {
          "description": "Input [Optional]. The spanner borg service account for delegating the kms key to. For example, spanner-infra-cmek-nonprod@system.gserviceaccount.com, for the nonprod universe.",
          "type": "string"
        },
        "spannerNamespace": {
          "type": "string"
        },
        "sdlBundlePath": {
          "description": "Input [Required]. The file path to the spanner SDL bundle.",
          "type": "string"
        },
        "spannerUniverse": {
          "description": "Input [Required]. Every database in Spanner can be identified by the following path name: /span//:",
          "type": "string"
        },
        "spannerLocalNamePrefix": {
          "type": "string"
        },
        "createDatabaseOptions": {
          "$ref": "CloudAiPlatformTenantresourceInfraSpannerConfigCreateDatabaseOptions",
          "description": "Input [Optional]. The options to create a spanner database. Note: give the right options to ensure the right KMS key access audit logging and AxT logging in expected logging category."
        },
        "kmsKeyReference": {
          "description": "Input [Optional]. The KMS key name or the KMS grant name used for CMEK encryption. Only set this field when provisioning new Infra Spanner databases. For existing Infra Spanner databases, this field will be ignored because CMEK re-encryption is not supported. For example, projects//locations//keyRings//cryptoKeys/",
          "type": "string"
        }
      },
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1TimestampTypeOptions": {
      "description": "Configurations for a timestamp property.",
      "properties": {},
      "id": "GoogleCloudContentwarehouseV1TimestampTypeOptions",
      "type": "object"
    },
    "GoogleCloudDocumentaiV1DocumentProvenance": {
      "type": "object",
      "id": "GoogleCloudDocumentaiV1DocumentProvenance",
      "description": "Structure to identify provenance relationships between annotations in different revisions.",
      "properties": {
        "revision": {
          "deprecated": true,
          "format": "int32",
          "description": "The index of the revision that produced this element.",
          "type": "integer"
        },
        "type": {
          "enumDescriptions": [
            "Operation type unspecified. If no operation is specified a provenance entry is simply used to match against a `parent`.",
            "Add an element.",
            "Remove an element identified by `parent`.",
            "Updates any fields within the given provenance scope of the message. It overwrites the fields rather than replacing them. Use this when you want to update a field value of an entity without also updating all the child properties.",
            "Currently unused. Replace an element identified by `parent`.",
            "Deprecated. Request human review for the element identified by `parent`.",
            "Deprecated. Element is reviewed and approved at human review, confidence will be set to 1.0.",
            "Deprecated. Element is skipped in the validation process."
          ],
          "enum": [
            "OPERATION_TYPE_UNSPECIFIED",
            "ADD",
            "REMOVE",
            "UPDATE",
            "REPLACE",
            "EVAL_REQUESTED",
            "EVAL_APPROVED",
            "EVAL_SKIPPED"
          ],
          "description": "The type of provenance operation.",
          "type": "string",
          "enumDeprecated": [
            false,
            false,
            false,
            false,
            false,
            true,
            true,
            true
          ]
        },
        "parents": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentProvenanceParent"
          },
          "description": "References to the original elements that are replaced."
        },
        "id": {
          "description": "The Id of this operation. Needs to be unique within the scope of the revision.",
          "format": "int32",
          "deprecated": true,
          "type": "integer"
        }
      }
    },
    "GoogleCloudContentwarehouseV1InitializeProjectRequest": {
      "id": "GoogleCloudContentwarehouseV1InitializeProjectRequest",
      "properties": {
        "enableCalUserEmailLogging": {
          "description": "Optional. Whether to enable CAL user email logging.",
          "type": "boolean"
        },
        "databaseType": {
          "description": "Required. The type of database used to store customer data",
          "enumDescriptions": [
            "This value is required by protobuf best practices",
            "Internal Spanner",
            "Cloud Sql with a Postgres Sql instance"
          ],
          "enum": [
            "DB_UNKNOWN",
            "DB_INFRA_SPANNER",
            "DB_CLOUD_SQL_POSTGRES"
          ],
          "enumDeprecated": [
            false,
            false,
            true
          ],
          "type": "string"
        },
        "kmsKey": {
          "type": "string",
          "description": "Optional. The KMS key used for CMEK encryption. It is required that the kms key is in the same region as the endpoint. The same key will be used for all provisioned resources, if encryption is available. If the kms_key is left empty, no encryption will be enforced."
        },
        "accessControlMode": {
          "enumDescriptions": [
            "This value is required by protobuf best practices",
            "Universal Access: No document level access control.",
            "Document level access control with customer own Identity Service.",
            "Document level access control using Google Cloud Identity."
          ],
          "enum": [
            "ACL_MODE_UNKNOWN",
            "ACL_MODE_UNIVERSAL_ACCESS",
            "ACL_MODE_DOCUMENT_LEVEL_ACCESS_CONTROL_BYOID",
            "ACL_MODE_DOCUMENT_LEVEL_ACCESS_CONTROL_GCI"
          ],
          "type": "string",
          "description": "Required. The access control mode for accessing the customer data"
        },
        "documentCreatorDefaultRole": {
          "enumDescriptions": [
            "Unspecified, will be default to document admin role.",
            "Document Admin, same as contentwarehouse.googleapis.com/documentAdmin.",
            "Document Editor, same as contentwarehouse.googleapis.com/documentEditor.",
            "Document Viewer, same as contentwarehouse.googleapis.com/documentViewer."
          ],
          "type": "string",
          "description": "Optional. The default role for the person who create a document.",
          "enum": [
            "DOCUMENT_CREATOR_DEFAULT_ROLE_UNSPECIFIED",
            "DOCUMENT_ADMIN",
            "DOCUMENT_EDITOR",
            "DOCUMENT_VIEWER"
          ]
        }
      },
      "type": "object",
      "description": "Request message for projectService.InitializeProject"
    },
    "GoogleCloudContentwarehouseV1beta1InitializeProjectResponse": {
      "type": "object",
      "properties": {
        "message": {
          "description": "The message of the project initialization process.",
          "type": "string"
        },
        "state": {
          "enum": [
            "STATE_UNSPECIFIED",
            "SUCCEEDED",
            "FAILED",
            "CANCELLED",
            "RUNNING"
          ],
          "enumDescriptions": [
            "Clients should never see this.",
            "Finished project initialization without error.",
            "Finished project initialization with an error.",
            "Client canceled the LRO.",
            "Ask the customer to check the operation for results."
          ],
          "type": "string",
          "description": "The state of the project initialization process."
        }
      },
      "description": "Response message for projectService.InitializeProject",
      "id": "GoogleCloudContentwarehouseV1beta1InitializeProjectResponse"
    },
    "GoogleCloudContentwarehouseV1Value": {
      "id": "GoogleCloudContentwarehouseV1Value",
      "type": "object",
      "description": "`Value` represents a dynamically typed value which can be either be a float, a integer, a string, or a datetime value. A producer of value is expected to set one of these variants. Absence of any variant indicates an error.",
      "properties": {
        "intValue": {
          "type": "integer",
          "description": "Represents a integer value.",
          "format": "int32"
        },
        "stringValue": {
          "description": "Represents a string value.",
          "type": "string"
        },
        "enumValue": {
          "$ref": "GoogleCloudContentwarehouseV1EnumValue",
          "description": "Represents an enum value."
        },
        "booleanValue": {
          "type": "boolean",
          "description": "Represents a boolean value."
        },
        "datetimeValue": {
          "$ref": "GoogleTypeDateTime",
          "description": "Represents a datetime value."
        },
        "floatValue": {
          "format": "float",
          "description": "Represents a float value.",
          "type": "number"
        },
        "timestampValue": {
          "description": "Represents a timestamp value.",
          "$ref": "GoogleCloudContentwarehouseV1TimestampValue"
        }
      }
    },
    "GoogleTypeDate": {
      "id": "GoogleTypeDate",
      "properties": {
        "month": {
          "type": "integer",
          "format": "int32",
          "description": "Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day."
        },
        "year": {
          "description": "Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.",
          "format": "int32",
          "type": "integer"
        },
        "day": {
          "type": "integer",
          "format": "int32",
          "description": "Day of a month. Must be from 1 to 31 and valid for the year and month, or 0 to specify a year by itself or a year and month where the day isn't significant."
        }
      },
      "type": "object",
      "description": "Represents a whole or partial calendar date, such as a birthday. The time of day and time zone are either specified elsewhere or are insignificant. The date is relative to the Gregorian Calendar. This can represent one of the following: * A full date, with non-zero year, month, and day values. * A month and day, with a zero year (for example, an anniversary). * A year on its own, with a zero month and a zero day. * A year and month, with a zero day (for example, a credit card expiration date). Related types: * google.type.TimeOfDay * google.type.DateTime * google.protobuf.Timestamp"
    },
    "GoogleCloudDocumentaiV1DocumentPageAnchor": {
      "id": "GoogleCloudDocumentaiV1DocumentPageAnchor",
      "properties": {
        "pageRefs": {
          "description": "One or more references to visual page elements",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageAnchorPageRef"
          }
        }
      },
      "type": "object",
      "description": "Referencing the visual context of the entity in the Document.pages. Page anchors can be cross-page, consist of multiple bounding polygons and optionally reference specific layout element types."
    },
    "GoogleCloudContentwarehouseV1LockDocumentRequest": {
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1LockDocumentRequest",
      "properties": {
        "collectionId": {
          "type": "string",
          "description": "The collection the document connects to."
        },
        "lockingUser": {
          "$ref": "GoogleCloudContentwarehouseV1UserInfo",
          "description": "The user information who locks the document."
        }
      },
      "description": "Request message for DocumentService.LockDocument."
    },
    "GoogleCloudDocumentaiV1DocumentProvenanceParent": {
      "type": "object",
      "properties": {
        "revision": {
          "format": "int32",
          "description": "The index of the index into current revision's parent_ids list.",
          "type": "integer"
        },
        "id": {
          "description": "The id of the parent provenance.",
          "deprecated": true,
          "type": "integer",
          "format": "int32"
        },
        "index": {
          "type": "integer",
          "description": "The index of the parent item in the corresponding item list (eg. list of entities, properties within entities, etc.) in the parent revision.",
          "format": "int32"
        }
      },
      "description": "The parent element the current element is based on. Used for referencing/aligning, removal and replacement operations.",
      "id": "GoogleCloudDocumentaiV1DocumentProvenanceParent"
    },
    "CloudAiPlatformTenantresourceTenantResource": {
      "id": "CloudAiPlatformTenantresourceTenantResource",
      "properties": {
        "tenantProjectResources": {
          "items": {
            "$ref": "CloudAiPlatformTenantresourceTenantProjectResource"
          },
          "description": "A list of tenant projects and tenant resources to provision or deprovision.",
          "type": "array"
        },
        "p4ServiceAccounts": {
          "items": {
            "$ref": "CloudAiPlatformTenantresourceServiceAccountIdentity"
          },
          "description": "A list of P4 service accounts (go/p4sa) to provision or deprovision.",
          "type": "array"
        }
      },
      "description": "A collection of tenant resources.",
      "type": "object"
    },
    "GoogleProtobufEmpty": {
      "description": "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); }",
      "id": "GoogleProtobufEmpty",
      "properties": {},
      "type": "object"
    },
    "GoogleCloudDocumentaiV1DocumentPageLayout": {
      "type": "object",
      "properties": {
        "orientation": {
          "enum": [
            "ORIENTATION_UNSPECIFIED",
            "PAGE_UP",
            "PAGE_RIGHT",
            "PAGE_DOWN",
            "PAGE_LEFT"
          ],
          "description": "Detected orientation for the Layout.",
          "type": "string",
          "enumDescriptions": [
            "Unspecified orientation.",
            "Orientation is aligned with page up.",
            "Orientation is aligned with page right. Turn the head 90 degrees clockwise from upright to read.",
            "Orientation is aligned with page down. Turn the head 180 degrees from upright to read.",
            "Orientation is aligned with page left. Turn the head 90 degrees counterclockwise from upright to read."
          ]
        },
        "confidence": {
          "type": "number",
          "format": "float",
          "description": "Confidence of the current Layout within context of the object this layout is for. e.g. confidence can be for a single token, a table, a visual element, etc. depending on context. Range `[0, 1]`."
        },
        "textAnchor": {
          "description": "Text anchor indexing into the Document.text.",
          "$ref": "GoogleCloudDocumentaiV1DocumentTextAnchor"
        },
        "boundingPoly": {
          "$ref": "GoogleCloudDocumentaiV1BoundingPoly",
          "description": "The bounding polygon for the Layout."
        }
      },
      "description": "Visual element describing a layout unit on a page.",
      "id": "GoogleCloudDocumentaiV1DocumentPageLayout"
    },
    "GoogleCloudContentwarehouseV1PropertyFilter": {
      "properties": {
        "documentSchemaName": {
          "type": "string",
          "description": "The Document schema name Document.document_schema_name. Format: projects/{project_number}/locations/{location}/documentSchemas/{document_schema_id}."
        },
        "condition": {
          "description": "The filter condition. The syntax for this expression is a subset of SQL syntax. Supported operators are: `=`, `!=`, `\u003c`, `\u003c=`, `\u003e`, `\u003e=`, and `~~` where the left of the operator is a property name and the right of the operator is a number or a quoted string. You must escape backslash (\\\\) and quote (\\\") characters. `~~` is the LIKE operator. The right of the operator must be a string. The only supported property data type for LIKE is text_values. It provides semantic search functionality by parsing, stemming and doing synonyms expansion against the input query. It matches if the property contains semantic similar content to the query. It is not regex matching or wildcard matching. For example, \"property.company ~~ \\\"google\\\"\" will match records whose property `property.compnay` have values like \"Google Inc.\", \"Google LLC\" or \"Google Company\". Supported functions are `LOWER([property_name])` to perform a case insensitive match and `EMPTY([property_name])` to filter on the existence of a key. Boolean expressions (AND/OR/NOT) are supported up to 3 levels of nesting (for example, \"((A AND B AND C) OR NOT D) AND E\"), a maximum of 100 comparisons or functions are allowed in the expression. The expression must be \u003c 6000 bytes in length. Only properties that are marked filterable are allowed (PropertyDefinition.is_filterable). Property names do not need to be prefixed by the document schema id (as is the case with histograms), however property names will need to be prefixed by its parent hierarchy, if any. For example: top_property_name.sub_property_name. Sample Query: `(LOWER(driving_license)=\"class \\\"a\\\"\" OR EMPTY(driving_license)) AND driving_years \u003e 10` CMEK compliant deployment only supports: * Operators: `=`, `\u003c`, `\u003c=`, `\u003e`, and `\u003e=`. * Boolean expressions: AND and OR.",
          "type": "string"
        }
      },
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1PropertyFilter"
    },
    "GoogleCloudDocumentaiV1DocumentPageTable": {
      "id": "GoogleCloudDocumentaiV1DocumentPageTable",
      "properties": {
        "headerRows": {
          "type": "array",
          "description": "Header rows of the table.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageTableTableRow"
          }
        },
        "bodyRows": {
          "type": "array",
          "description": "Body rows of the table.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageTableTableRow"
          }
        },
        "layout": {
          "description": "Layout for Table.",
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout"
        },
        "provenance": {
          "$ref": "GoogleCloudDocumentaiV1DocumentProvenance",
          "description": "The history of this table.",
          "deprecated": true
        },
        "detectedLanguages": {
          "description": "A list of detected languages together with confidence.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage"
          }
        }
      },
      "type": "object",
      "description": "A table representation similar to HTML table structure."
    },
    "GoogleCloudDocumentaiV1DocumentTextAnchorTextSegment": {
      "type": "object",
      "description": "A text segment in the Document.text. The indices may be out of bounds which indicate that the text extends into another document shard for large sharded documents. See ShardInfo.text_offset",
      "id": "GoogleCloudDocumentaiV1DocumentTextAnchorTextSegment",
      "properties": {
        "startIndex": {
          "description": "TextSegment start UTF-8 char index in the Document.text.",
          "format": "int64",
          "type": "string"
        },
        "endIndex": {
          "type": "string",
          "format": "int64",
          "description": "TextSegment half open end UTF-8 char index in the Document.text."
        }
      }
    },
    "GoogleCloudContentwarehouseV1FloatArray": {
      "properties": {
        "values": {
          "items": {
            "type": "number",
            "format": "float"
          },
          "type": "array",
          "description": "List of float values."
        }
      },
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1FloatArray",
      "description": "Float values."
    },
    "GoogleCloudDocumentaiV1DocumentPageImage": {
      "type": "object",
      "description": "Rendered image contents for this page.",
      "id": "GoogleCloudDocumentaiV1DocumentPageImage",
      "properties": {
        "height": {
          "format": "int32",
          "type": "integer",
          "description": "Height of the image in pixels."
        },
        "mimeType": {
          "description": "Encoding [media type (MIME type)](https://www.iana.org/assignments/media-types/media-types.xhtml) for the image.",
          "type": "string"
        },
        "content": {
          "type": "string",
          "description": "Raw byte content of the image.",
          "format": "byte"
        },
        "width": {
          "format": "int32",
          "description": "Width of the image in pixels.",
          "type": "integer"
        }
      }
    },
    "GoogleCloudDocumentaiV1DocumentRevisionHumanReview": {
      "description": "Human Review information of the document.",
      "type": "object",
      "id": "GoogleCloudDocumentaiV1DocumentRevisionHumanReview",
      "properties": {
        "state": {
          "type": "string",
          "description": "Human review state. e.g. `requested`, `succeeded`, `rejected`."
        },
        "stateMessage": {
          "description": "A message providing more details about the current state of processing. For example, the rejection reason when the state is `rejected`.",
          "type": "string"
        }
      }
    },
    "CloudAiPlatformTenantresourceTenantProjectResource": {
      "id": "CloudAiPlatformTenantresourceTenantProjectResource",
      "type": "object",
      "description": "The tenant project and tenant resources. Next ID: 10",
      "properties": {
        "tenantServiceAccounts": {
          "items": {
            "$ref": "CloudAiPlatformTenantresourceTenantServiceAccountIdentity"
          },
          "description": "The service account identities (or enabled API service's P4SA) that are expclicitly created under the tenant project (before JIT provisioning during enabled API services).",
          "type": "array"
        },
        "tag": {
          "type": "string",
          "description": "Input/Output [Required]. The tag that uniquely identifies a tenant project within a tenancy unit. Note: for the same tenant project tag, all tenant manager operations should be idempotent."
        },
        "tenantProjectConfig": {
          "$ref": "CloudAiPlatformTenantresourceTenantProjectConfig",
          "description": "The configurations of a tenant project."
        },
        "infraSpannerConfigs": {
          "type": "array",
          "description": "The Infra Spanner databases that are provisioned under the tenant project. Note: this is an experimental feature.",
          "items": {
            "$ref": "CloudAiPlatformTenantresourceInfraSpannerConfig"
          }
        },
        "tenantProjectId": {
          "type": "string",
          "description": "Output only. The tenant project ID that has been created."
        },
        "tenantProjectNumber": {
          "format": "int64",
          "description": "Output only. The tenant project number that has been created.",
          "type": "string"
        },
        "gcsBuckets": {
          "type": "array",
          "description": "The GCS buckets that are provisioned under the tenant project.",
          "items": {
            "$ref": "CloudAiPlatformTenantresourceGcsBucketConfig"
          }
        },
        "cloudSqlInstances": {
          "description": "The CloudSQL instances that are provisioned under the tenant project.",
          "items": {
            "$ref": "CloudAiPlatformTenantresourceCloudSqlInstanceConfig"
          },
          "type": "array"
        },
        "iamPolicyBindings": {
          "description": "The dynamic IAM bindings that are granted under the tenant project. Note: this should only add new bindings to the project if they don't exist and the existing bindings won't be affected.",
          "type": "array",
          "items": {
            "$ref": "CloudAiPlatformTenantresourceIamPolicyBinding"
          }
        }
      }
    },
    "GoogleCloudDocumentaiV1NormalizedVertex": {
      "description": "A vertex represents a 2D point in the image. NOTE: the normalized vertex coordinates are relative to the original image and range from 0 to 1.",
      "properties": {
        "x": {
          "format": "float",
          "description": "X coordinate.",
          "type": "number"
        },
        "y": {
          "type": "number",
          "description": "Y coordinate (starts from the top of the image).",
          "format": "float"
        }
      },
      "id": "GoogleCloudDocumentaiV1NormalizedVertex",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1UpdateRuleSetRequest": {
      "id": "GoogleCloudContentwarehouseV1UpdateRuleSetRequest",
      "properties": {
        "ruleSet": {
          "description": "Required. The rule set to update.",
          "$ref": "GoogleCloudContentwarehouseV1RuleSet"
        }
      },
      "type": "object",
      "description": "Request message for RuleSetService.UpdateRuleSet."
    },
    "GoogleCloudDocumentaiV1DocumentPageParagraph": {
      "properties": {
        "detectedLanguages": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage"
          },
          "description": "A list of detected languages together with confidence."
        },
        "provenance": {
          "deprecated": true,
          "$ref": "GoogleCloudDocumentaiV1DocumentProvenance",
          "description": "The history of this annotation."
        },
        "layout": {
          "description": "Layout for Paragraph.",
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout"
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentPageParagraph",
      "description": "A collection of lines that a human would perceive as a paragraph.",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1SetAclResponse": {
      "description": "Response message for DocumentService.SetAcl.",
      "properties": {
        "policy": {
          "$ref": "GoogleIamV1Policy",
          "description": "The policy will be attached to a resource (e.g. projecct, document)."
        },
        "metadata": {
          "description": "Additional information for the API invocation, such as the request tracking id.",
          "$ref": "GoogleCloudContentwarehouseV1ResponseMetadata"
        }
      },
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1SetAclResponse"
    },
    "GoogleCloudDocumentaiV1DocumentChunkedDocument": {
      "description": "Represents the chunks that the document is divided into.",
      "id": "GoogleCloudDocumentaiV1DocumentChunkedDocument",
      "properties": {
        "chunks": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunk"
          },
          "type": "array",
          "description": "List of chunks."
        }
      },
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1RunPipelineMetadataGcsIngestPipelineMetadata": {
      "properties": {
        "inputPath": {
          "type": "string",
          "description": "The input Cloud Storage folder in this pipeline. Format: `gs:///`."
        }
      },
      "id": "GoogleCloudContentwarehouseV1RunPipelineMetadataGcsIngestPipelineMetadata",
      "description": "The metadata message for GcsIngest pipeline.",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1ActionExecutorOutput": {
      "id": "GoogleCloudContentwarehouseV1ActionExecutorOutput",
      "description": "Represents the output of the Action Executor.",
      "type": "object",
      "properties": {
        "ruleActionsPairs": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1RuleActionsPair"
          },
          "description": "List of rule and corresponding actions result."
        }
      }
    },
    "GoogleCloudContentwarehouseV1PropertyArray": {
      "description": "Property values.",
      "type": "object",
      "properties": {
        "properties": {
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1Property"
          },
          "type": "array",
          "description": "List of property values."
        }
      },
      "id": "GoogleCloudContentwarehouseV1PropertyArray"
    },
    "GoogleCloudContentwarehouseV1ProjectStatus": {
      "id": "GoogleCloudContentwarehouseV1ProjectStatus",
      "description": "Status of a project, including the project state, dbType, aclMode and etc.",
      "properties": {
        "location": {
          "type": "string",
          "description": "The location of the queried project."
        },
        "state": {
          "enum": [
            "PROJECT_STATE_UNSPECIFIED",
            "PROJECT_STATE_PENDING",
            "PROJECT_STATE_COMPLETED",
            "PROJECT_STATE_FAILED",
            "PROJECT_STATE_DELETING",
            "PROJECT_STATE_DELETING_FAILED",
            "PROJECT_STATE_DELETED",
            "PROJECT_STATE_NOT_FOUND"
          ],
          "enumDescriptions": [
            "Default status, required by protobuf best practices.",
            "The project is in the middle of a provision process.",
            "All dependencies have been provisioned.",
            "A provision process was previously initiated, but failed.",
            "The project is in the middle of a deletion process.",
            "A deleting process was initiated, but failed.",
            "The project is deleted.",
            "The project is not found."
          ],
          "type": "string",
          "description": "State of the project."
        },
        "databaseType": {
          "type": "string",
          "enum": [
            "DB_UNKNOWN",
            "DB_INFRA_SPANNER",
            "DB_CLOUD_SQL_POSTGRES"
          ],
          "enumDeprecated": [
            false,
            false,
            true
          ],
          "description": "Database type.",
          "enumDescriptions": [
            "This value is required by protobuf best practices",
            "Internal Spanner",
            "Cloud Sql with a Postgres Sql instance"
          ]
        },
        "accessControlMode": {
          "enum": [
            "ACL_MODE_UNKNOWN",
            "ACL_MODE_UNIVERSAL_ACCESS",
            "ACL_MODE_DOCUMENT_LEVEL_ACCESS_CONTROL_BYOID",
            "ACL_MODE_DOCUMENT_LEVEL_ACCESS_CONTROL_GCI"
          ],
          "enumDescriptions": [
            "This value is required by protobuf best practices",
            "Universal Access: No document level access control.",
            "Document level access control with customer own Identity Service.",
            "Document level access control using Google Cloud Identity."
          ],
          "description": "Access control mode.",
          "type": "string"
        },
        "qaEnabled": {
          "description": "If the qa is enabled on this project.",
          "type": "boolean"
        },
        "documentCreatorDefaultRole": {
          "description": "The default role for the person who create a document.",
          "type": "string"
        }
      },
      "type": "object"
    },
    "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutListEntry": {
      "description": "Represents an entry in the list.",
      "properties": {
        "blocks": {
          "description": "A list entry is a list of blocks. Repeated blocks support further hierarchies and nested blocks.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlock"
          }
        }
      },
      "type": "object",
      "id": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutListEntry"
    },
    "GoogleCloudDocumentaiV1DocumentPageDetectedBarcode": {
      "type": "object",
      "description": "A detected barcode.",
      "properties": {
        "barcode": {
          "$ref": "GoogleCloudDocumentaiV1Barcode",
          "description": "Detailed barcode information of the DetectedBarcode."
        },
        "layout": {
          "description": "Layout for DetectedBarcode.",
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout"
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentPageDetectedBarcode"
    },
    "GoogleCloudContentwarehouseV1ExportToCdwPipeline": {
      "type": "object",
      "description": "The configuration of exporting documents from the Document Warehouse to CDW pipeline.",
      "id": "GoogleCloudContentwarehouseV1ExportToCdwPipeline",
      "properties": {
        "docAiDataset": {
          "description": "Optional. The CDW dataset resource name. This field is optional. If not set, the documents will be exported to Cloud Storage only. Format: projects/{project}/locations/{location}/processors/{processor}/dataset",
          "type": "string"
        },
        "documents": {
          "type": "array",
          "description": "The list of all the resource names of the documents to be processed. Format: projects/{project_number}/locations/{location}/documents/{document_id}.",
          "items": {
            "type": "string"
          }
        },
        "exportFolderPath": {
          "description": "The Cloud Storage folder path used to store the exported documents before being sent to CDW. Format: `gs:///`.",
          "type": "string"
        },
        "trainingSplitRatio": {
          "type": "number",
          "description": "Ratio of training dataset split. When importing into Document AI Workbench, documents will be automatically split into training and test split category with the specified ratio. This field is required if doc_ai_dataset is set.",
          "format": "float"
        }
      }
    },
    "GoogleCloudContentwarehouseV1SearchDocumentsResponseMatchingDocument": {
      "properties": {
        "matchedTokenPageIndices": {
          "description": "Return the 1-based page indices where those pages have one or more matched tokens.",
          "type": "array",
          "items": {
            "format": "int64",
            "type": "string"
          }
        },
        "document": {
          "$ref": "GoogleCloudContentwarehouseV1Document",
          "description": "Document that matches the specified SearchDocumentsRequest. This document only contains indexed metadata information."
        },
        "searchTextSnippet": {
          "description": "Contains snippets of text from the document full raw text that most closely match a search query's keywords, if available. All HTML tags in the original fields are stripped when returned in this field, and matching query keywords are enclosed in HTML bold tags. If the question-answering feature is enabled, this field will instead contain a snippet that answers the user's natural-language query. No HTML bold tags will be present, and highlights in the answer snippet can be found in QAResult.highlights.",
          "type": "string"
        },
        "qaResult": {
          "description": "Experimental. Additional result info if the question-answering feature is enabled.",
          "$ref": "GoogleCloudContentwarehouseV1QAResult"
        }
      },
      "id": "GoogleCloudContentwarehouseV1SearchDocumentsResponseMatchingDocument",
      "description": "Document entry with metadata inside SearchDocumentsResponse",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1UpdateDocumentRequest": {
      "id": "GoogleCloudContentwarehouseV1UpdateDocumentRequest",
      "properties": {
        "updateOptions": {
          "description": "Options for the update operation.",
          "$ref": "GoogleCloudContentwarehouseV1UpdateOptions"
        },
        "document": {
          "$ref": "GoogleCloudContentwarehouseV1Document",
          "description": "Required. The document to update."
        },
        "cloudAiDocumentOption": {
          "description": "Request Option for processing Cloud AI Document in Document Warehouse. This field offers limited support for mapping entities from Cloud AI Document to Warehouse Document. Please consult with product team before using this field and other available options.",
          "$ref": "GoogleCloudContentwarehouseV1CloudAIDocumentOption"
        },
        "requestMetadata": {
          "$ref": "GoogleCloudContentwarehouseV1RequestMetadata",
          "description": "The meta information collected about the end user, used to enforce access control for the service."
        }
      },
      "type": "object",
      "description": "Request message for DocumentService.UpdateDocument."
    },
    "GoogleCloudContentwarehouseV1UpdateDocumentResponse": {
      "type": "object",
      "properties": {
        "ruleEngineOutput": {
          "$ref": "GoogleCloudContentwarehouseV1RuleEngineOutput",
          "description": "Output from Rule Engine recording the rule evaluator and action executor's output. Refer format in: google/cloud/contentwarehouse/v1/rule_engine.proto"
        },
        "document": {
          "description": "Updated document after executing update request.",
          "$ref": "GoogleCloudContentwarehouseV1Document"
        },
        "metadata": {
          "$ref": "GoogleCloudContentwarehouseV1ResponseMetadata",
          "description": "Additional information for the API invocation, such as the request tracking id."
        }
      },
      "description": "Response message for DocumentService.UpdateDocument.",
      "id": "GoogleCloudContentwarehouseV1UpdateDocumentResponse"
    },
    "GoogleCloudContentwarehouseV1CreateDocumentResponse": {
      "description": "Response message for DocumentService.CreateDocument.",
      "id": "GoogleCloudContentwarehouseV1CreateDocumentResponse",
      "properties": {
        "document": {
          "$ref": "GoogleCloudContentwarehouseV1Document",
          "description": "Document created after executing create request."
        },
        "metadata": {
          "description": "Additional information for the API invocation, such as the request tracking id.",
          "$ref": "GoogleCloudContentwarehouseV1ResponseMetadata"
        },
        "ruleEngineOutput": {
          "description": "Output from Rule Engine recording the rule evaluator and action executor's output. Refer format in: google/cloud/contentwarehouse/v1/rule_engine.proto",
          "$ref": "GoogleCloudContentwarehouseV1RuleEngineOutput"
        },
        "longRunningOperations": {
          "description": "post-processing LROs",
          "type": "array",
          "items": {
            "$ref": "GoogleLongrunningOperation"
          }
        }
      },
      "type": "object"
    },
    "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutListBlock": {
      "id": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutListBlock",
      "description": "Represents a list type block.",
      "type": "object",
      "properties": {
        "listEntries": {
          "description": "List entries that constitute a list block.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutListEntry"
          }
        },
        "type": {
          "description": "Type of the list_entries (if exist). Available options are `ordered` and `unordered`.",
          "type": "string"
        }
      }
    },
    "GoogleCloudDocumentaiV1DocumentPageFormField": {
      "description": "A form field detected on the page.",
      "properties": {
        "fieldValue": {
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout",
          "description": "Layout for the FormField value."
        },
        "valueDetectedLanguages": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage"
          },
          "description": "A list of detected languages for value together with confidence.",
          "type": "array"
        },
        "correctedValueText": {
          "type": "string",
          "description": "Created for Labeling UI to export value text. If corrections were made to the text identified by the `field_value.text_anchor`, this field will contain the correction."
        },
        "provenance": {
          "$ref": "GoogleCloudDocumentaiV1DocumentProvenance",
          "description": "The history of this annotation."
        },
        "fieldName": {
          "description": "Layout for the FormField name. e.g. `Address`, `Email`, `Grand total`, `Phone number`, etc.",
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout"
        },
        "valueType": {
          "type": "string",
          "description": "If the value is non-textual, this field represents the type. Current valid values are: - blank (this indicates the `field_value` is normal text) - `unfilled_checkbox` - `filled_checkbox`"
        },
        "correctedKeyText": {
          "type": "string",
          "description": "Created for Labeling UI to export key text. If corrections were made to the text identified by the `field_name.text_anchor`, this field will contain the correction."
        },
        "nameDetectedLanguages": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage"
          },
          "type": "array",
          "description": "A list of detected languages for name together with confidence."
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentPageFormField",
      "type": "object"
    },
    "GoogleLongrunningOperation": {
      "id": "GoogleLongrunningOperation",
      "description": "This resource represents a long-running operation that is the result of a network API call.",
      "type": "object",
      "properties": {
        "done": {
          "type": "boolean",
          "description": "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": {
          "description": "The error result of the operation in case of failure or cancellation.",
          "$ref": "GoogleRpcStatus"
        },
        "metadata": {
          "description": "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.",
          "additionalProperties": {
            "description": "Properties of the object. Contains field @type with type URL.",
            "type": "any"
          },
          "type": "object"
        },
        "response": {
          "additionalProperties": {
            "description": "Properties of the object. Contains field @type with type URL.",
            "type": "any"
          },
          "description": "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`.",
          "type": "object"
        },
        "name": {
          "type": "string",
          "description": "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}`."
        }
      }
    },
    "GoogleCloudContentwarehouseV1ListSynonymSetsResponse": {
      "description": "Response message for SynonymSetService.ListSynonymSets.",
      "id": "GoogleCloudContentwarehouseV1ListSynonymSetsResponse",
      "properties": {
        "nextPageToken": {
          "description": "A page token, received from a previous `ListSynonymSets` call. Provide this to retrieve the subsequent page.",
          "type": "string"
        },
        "synonymSets": {
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1SynonymSet"
          },
          "description": "The synonymSets from the specified parent.",
          "type": "array"
        }
      },
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1MapTypeOptions": {
      "description": "Configurations for a Map property.",
      "properties": {},
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1MapTypeOptions"
    },
    "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunkChunkPageSpan": {
      "id": "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunkChunkPageSpan",
      "type": "object",
      "properties": {
        "pageEnd": {
          "format": "int32",
          "type": "integer",
          "description": "Page where chunk ends in the document."
        },
        "pageStart": {
          "description": "Page where chunk starts in the document.",
          "type": "integer",
          "format": "int32"
        }
      },
      "description": "Represents where the chunk starts and ends in the document."
    },
    "GoogleCloudContentwarehouseV1PublishAction": {
      "properties": {
        "messages": {
          "items": {
            "type": "string"
          },
          "description": "Messages to be published.",
          "type": "array"
        },
        "topicId": {
          "type": "string",
          "description": "The topic id in the Pub/Sub service for which messages will be published to."
        }
      },
      "description": "Represents the action responsible for publishing messages to a Pub/Sub topic.",
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1PublishAction"
    },
    "GoogleCloudDocumentaiV1DocumentPageTokenDetectedBreak": {
      "description": "Detected break at the end of a Token.",
      "id": "GoogleCloudDocumentaiV1DocumentPageTokenDetectedBreak",
      "properties": {
        "type": {
          "enumDescriptions": [
            "Unspecified break type.",
            "A single whitespace.",
            "A wider whitespace.",
            "A hyphen that indicates that a token has been split across lines."
          ],
          "enum": [
            "TYPE_UNSPECIFIED",
            "SPACE",
            "WIDE_SPACE",
            "HYPHEN"
          ],
          "type": "string",
          "description": "Detected break type."
        }
      },
      "type": "object"
    },
    "GoogleCloudDocumentaiV1DocumentPageToken": {
      "type": "object",
      "id": "GoogleCloudDocumentaiV1DocumentPageToken",
      "properties": {
        "styleInfo": {
          "description": "Text style attributes.",
          "$ref": "GoogleCloudDocumentaiV1DocumentPageTokenStyleInfo"
        },
        "provenance": {
          "description": "The history of this annotation.",
          "$ref": "GoogleCloudDocumentaiV1DocumentProvenance",
          "deprecated": true
        },
        "detectedLanguages": {
          "description": "A list of detected languages together with confidence.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage"
          },
          "type": "array"
        },
        "detectedBreak": {
          "description": "Detected break at the end of a Token.",
          "$ref": "GoogleCloudDocumentaiV1DocumentPageTokenDetectedBreak"
        },
        "layout": {
          "description": "Layout for Token.",
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout"
        }
      },
      "description": "A detected token."
    },
    "GoogleCloudContentwarehouseV1FetchAclRequest": {
      "description": "Request message for DocumentService.FetchAcl",
      "properties": {
        "requestMetadata": {
          "$ref": "GoogleCloudContentwarehouseV1RequestMetadata",
          "description": "The meta information collected about the end user, used to enforce access control for the service."
        },
        "projectOwner": {
          "type": "boolean",
          "description": "For Get Project ACL only. Authorization check for end user will be ignored when project_owner=true."
        }
      },
      "id": "GoogleCloudContentwarehouseV1FetchAclRequest",
      "type": "object"
    },
    "GoogleCloudDocumentaiV1Barcode": {
      "type": "object",
      "description": "Encodes the detailed information of a barcode.",
      "properties": {
        "format": {
          "type": "string",
          "description": "Format of a barcode. The supported formats are: - `CODE_128`: Code 128 type. - `CODE_39`: Code 39 type. - `CODE_93`: Code 93 type. - `CODABAR`: Codabar type. - `DATA_MATRIX`: 2D Data Matrix type. - `ITF`: ITF type. - `EAN_13`: EAN-13 type. - `EAN_8`: EAN-8 type. - `QR_CODE`: 2D QR code type. - `UPC_A`: UPC-A type. - `UPC_E`: UPC-E type. - `PDF417`: PDF417 type. - `AZTEC`: 2D Aztec code type. - `DATABAR`: GS1 DataBar code type."
        },
        "valueFormat": {
          "description": "Value format describes the format of the value that a barcode encodes. The supported formats are: - `CONTACT_INFO`: Contact information. - `EMAIL`: Email address. - `ISBN`: ISBN identifier. - `PHONE`: Phone number. - `PRODUCT`: Product. - `SMS`: SMS message. - `TEXT`: Text string. - `URL`: URL address. - `WIFI`: Wifi information. - `GEO`: Geo-localization. - `CALENDAR_EVENT`: Calendar event. - `DRIVER_LICENSE`: Driver's license.",
          "type": "string"
        },
        "rawValue": {
          "type": "string",
          "description": "Raw value encoded in the barcode. For example: `'MEBKM:TITLE:Google;URL:https://www.google.com;;'`."
        }
      },
      "id": "GoogleCloudDocumentaiV1Barcode"
    },
    "GoogleApiServiceconsumermanagementV1PolicyBinding": {
      "type": "object",
      "description": "Translates to IAM Policy bindings (without auditing at this level)",
      "properties": {
        "role": {
          "description": "Role. (https://cloud.google.com/iam/docs/understanding-roles) For example, `roles/viewer`, `roles/editor`, or `roles/owner`.",
          "type": "string"
        },
        "members": {
          "description": "Uses the same format as in IAM policy. `member` must include both a prefix and ID. For example, `user:{emailId}`, `serviceAccount:{emailId}`, `group:{emailId}`.",
          "type": "array",
          "items": {
            "type": "string"
          }
        }
      },
      "id": "GoogleApiServiceconsumermanagementV1PolicyBinding"
    },
    "GoogleCloudContentwarehouseV1FloatTypeOptions": {
      "type": "object",
      "properties": {},
      "id": "GoogleCloudContentwarehouseV1FloatTypeOptions",
      "description": "Configurations for a float property."
    },
    "GoogleCloudContentwarehouseV1IntegerTypeOptions": {
      "type": "object",
      "properties": {},
      "description": "Configurations for an integer property.",
      "id": "GoogleCloudContentwarehouseV1IntegerTypeOptions"
    },
    "GoogleCloudContentwarehouseV1Document": {
      "properties": {
        "inlineRawDocument": {
          "type": "string",
          "description": "Raw document content.",
          "format": "byte"
        },
        "documentSchemaName": {
          "type": "string",
          "description": "The Document schema name. Format: projects/{project_number}/locations/{location}/documentSchemas/{document_schema_id}."
        },
        "textExtractionEnabled": {
          "type": "boolean",
          "description": "If true, text extraction will be performed."
        },
        "createTime": {
          "format": "google-datetime",
          "description": "Output only. The time when the document is created.",
          "readOnly": true,
          "type": "string"
        },
        "dispositionTime": {
          "format": "google-datetime",
          "type": "string",
          "readOnly": true,
          "description": "Output only. If linked to a Collection with RetentionPolicy, the date when the document becomes mutable."
        },
        "properties": {
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1Property"
          },
          "description": "List of values that are user supplied metadata.",
          "type": "array"
        },
        "rawDocumentPath": {
          "type": "string",
          "description": "Raw document file in Cloud Storage path."
        },
        "legalHold": {
          "description": "Output only. Indicates if the document has a legal hold on it.",
          "type": "boolean",
          "readOnly": true
        },
        "textExtractionDisabled": {
          "description": "If true, text extraction will not be performed.",
          "deprecated": true,
          "type": "boolean"
        },
        "updateTime": {
          "description": "Output only. The time when the document is last updated.",
          "type": "string",
          "format": "google-datetime",
          "readOnly": true
        },
        "creator": {
          "type": "string",
          "description": "The user who creates the document."
        },
        "plainText": {
          "type": "string",
          "description": "Other document format, such as PPTX, XLXS"
        },
        "cloudAiDocument": {
          "$ref": "GoogleCloudDocumentaiV1Document",
          "description": "Document AI format to save the structured content, including OCR."
        },
        "contentCategory": {
          "enumDescriptions": [
            "No category is specified.",
            "Content is of image type.",
            "Content is of audio type.",
            "Content is of video type."
          ],
          "description": "Indicates the category (image, audio, video etc.) of the original content.",
          "type": "string",
          "enum": [
            "CONTENT_CATEGORY_UNSPECIFIED",
            "CONTENT_CATEGORY_IMAGE",
            "CONTENT_CATEGORY_AUDIO",
            "CONTENT_CATEGORY_VIDEO"
          ]
        },
        "updater": {
          "description": "The user who lastly updates the document.",
          "type": "string"
        },
        "referenceId": {
          "description": "The reference ID set by customers. Must be unique per project and location.",
          "type": "string"
        },
        "displayUri": {
          "description": "Uri to display the document, for example, in the UI.",
          "type": "string"
        },
        "rawDocumentFileType": {
          "enum": [
            "RAW_DOCUMENT_FILE_TYPE_UNSPECIFIED",
            "RAW_DOCUMENT_FILE_TYPE_PDF",
            "RAW_DOCUMENT_FILE_TYPE_DOCX",
            "RAW_DOCUMENT_FILE_TYPE_XLSX",
            "RAW_DOCUMENT_FILE_TYPE_PPTX",
            "RAW_DOCUMENT_FILE_TYPE_TEXT",
            "RAW_DOCUMENT_FILE_TYPE_TIFF"
          ],
          "type": "string",
          "description": "This is used when DocAI was not used to load the document and parsing/ extracting is needed for the inline_raw_document. For example, if inline_raw_document is the byte representation of a PDF file, then this should be set to: RAW_DOCUMENT_FILE_TYPE_PDF.",
          "enumDescriptions": [
            "No raw document specified or it is non-parsable",
            "Adobe PDF format",
            "Microsoft Word format",
            "Microsoft Excel format",
            "Microsoft Powerpoint format",
            "UTF-8 encoded text format",
            "TIFF or TIF image file format"
          ]
        },
        "name": {
          "description": "The resource name of the document. Format: projects/{project_number}/locations/{location}/documents/{document_id}. The name is ignored when creating a document.",
          "type": "string"
        },
        "displayName": {
          "type": "string",
          "description": "Required. Display name of the document given by the user. This name will be displayed in the UI. Customer can populate this field with the name of the document. This differs from the 'title' field as 'title' is optional and stores the top heading in the document."
        },
        "title": {
          "type": "string",
          "description": "Title that describes the document. This can be the top heading or text that describes the document."
        }
      },
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1Document",
      "description": "Defines the structure for content warehouse document proto."
    },
    "GoogleCloudContentwarehouseV1ActionOutput": {
      "type": "object",
      "description": "Represents the result of executing an action.",
      "id": "GoogleCloudContentwarehouseV1ActionOutput",
      "properties": {
        "actionId": {
          "type": "string",
          "description": "ID of the action."
        },
        "actionState": {
          "enum": [
            "UNKNOWN",
            "ACTION_SUCCEEDED",
            "ACTION_FAILED",
            "ACTION_TIMED_OUT",
            "ACTION_PENDING"
          ],
          "enumDescriptions": [
            "The unknown state.",
            "State indicating action executed successfully.",
            "State indicating action failed.",
            "State indicating action timed out.",
            "State indicating action is pending."
          ],
          "type": "string",
          "description": "State of an action."
        },
        "outputMessage": {
          "description": "Action execution output message.",
          "type": "string"
        }
      }
    },
    "GoogleCloudContentwarehouseV1DocumentQuery": {
      "type": "object",
      "properties": {
        "propertyFilter": {
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1PropertyFilter"
          },
          "type": "array",
          "description": "This filter specifies a structured syntax to match against the PropertyDefinition.is_filterable marked as `true`. The relationship between the PropertyFilters is OR."
        },
        "documentSchemaNames": {
          "description": "This filter specifies the exact document schema Document.document_schema_name of the documents to search against. If a value isn't specified, documents within the search results are associated with any schema. If multiple values are specified, documents within the search results may be associated with any of the specified schemas. At most 20 document schema names are allowed.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "query": {
          "description": "The query string that matches against the full text of the document and the searchable properties. The query partially supports [Google AIP style syntax](https://google.aip.dev/160). Specifically, the query supports literals, logical operators, negation operators, comparison operators, and functions. Literals: A bare literal value (examples: \"42\", \"Hugo\") is a value to be matched against. It searches over the full text of the document and the searchable properties. Logical operators: \"AND\", \"and\", \"OR\", and \"or\" are binary logical operators (example: \"engineer OR developer\"). Negation operators: \"NOT\" and \"!\" are negation operators (example: \"NOT software\"). Comparison operators: support the binary comparison operators =, !=, \u003c, \u003e, \u003c= and \u003e= for string, numeric, enum, boolean. Also support like operator `~~` for string. It provides semantic search functionality by parsing, stemming and doing synonyms expansion against the input query. To specify a property in the query, the left hand side expression in the comparison must be the property ID including the parent. The right hand side must be literals. For example: \"\\\"projects/123/locations/us\\\".property_a \u003c 1\" matches results whose \"property_a\" is less than 1 in project 123 and us location. The literals and comparison expression can be connected in a single query (example: \"software engineer \\\"projects/123/locations/us\\\".salary \u003e 100\"). Functions: supported functions are `LOWER([property_name])` to perform a case insensitive match and `EMPTY([property_name])` to filter on the existence of a key. Support nested expressions connected using parenthesis and logical operators. The default logical operators is `AND` if there is no operators between expressions. The query can be used with other filters e.g. `time_filters` and `folder_name_filter`. They are connected with `AND` operator under the hood. The maximum number of allowed characters is 255.",
          "type": "string"
        },
        "timeFilters": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1TimeFilter"
          },
          "description": "Documents created/updated within a range specified by this filter are searched against."
        },
        "queryContext": {
          "description": "For custom synonyms. Customers provide the synonyms based on context. One customer can provide multiple set of synonyms based on different context. The search query will be expanded based on the custom synonyms of the query context set. By default, no custom synonyms wll be applied if no query context is provided. It is not supported for CMEK compliant deployment.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "documentCreatorFilter": {
          "description": "The exact creator(s) of the documents to search against. If a value isn't specified, documents within the search results are associated with any creator. If multiple values are specified, documents within the search results may be associated with any of the specified creators.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "isNlQuery": {
          "type": "boolean",
          "description": "Experimental, do not use. If the query is a natural language question. False by default. If true, then the question-answering feature will be used instead of search, and `result_count` in SearchDocumentsRequest must be set. In addition, all other input fields related to search (pagination, histograms, etc.) will be ignored."
        },
        "folderNameFilter": {
          "type": "string",
          "description": "Search all the documents under this specified folder. Format: projects/{project_number}/locations/{location}/documents/{document_id}."
        },
        "documentNameFilter": {
          "type": "array",
          "description": "Search the documents in the list. Format: projects/{project_number}/locations/{location}/documents/{document_id}.",
          "items": {
            "type": "string"
          }
        },
        "customPropertyFilter": {
          "type": "string",
          "deprecated": true,
          "description": "This filter specifies a structured syntax to match against the [PropertyDefinition].is_filterable marked as `true`. The syntax for this expression is a subset of SQL syntax. Supported operators are: `=`, `!=`, `\u003c`, `\u003c=`, `\u003e`, and `\u003e=` where the left of the operator is a property name and the right of the operator is a number or a quoted string. You must escape backslash (\\\\) and quote (\\\") characters. Supported functions are `LOWER([property_name])` to perform a case insensitive match and `EMPTY([property_name])` to filter on the existence of a key. Boolean expressions (AND/OR/NOT) are supported up to 3 levels of nesting (for example, \"((A AND B AND C) OR NOT D) AND E\"), a maximum of 100 comparisons or functions are allowed in the expression. The expression must be \u003c 6000 bytes in length. Sample Query: `(LOWER(driving_license)=\"class \\\"a\\\"\" OR EMPTY(driving_license)) AND driving_years \u003e 10`"
        },
        "customWeightsMetadata": {
          "$ref": "GoogleCloudContentwarehouseV1CustomWeightsMetadata",
          "description": "To support the custom weighting across document schemas, customers need to provide the properties to be used to boost the ranking in the search request. For a search query with CustomWeightsMetadata specified, only the RetrievalImportance for the properties in the CustomWeightsMetadata will be honored."
        },
        "fileTypeFilter": {
          "$ref": "GoogleCloudContentwarehouseV1FileTypeFilter",
          "description": "This filter specifies the types of files to return: ALL, FOLDER, or FILE. If FOLDER or FILE is specified, then only either folders or files will be returned, respectively. If ALL is specified, both folders and files will be returned. If no value is specified, ALL files will be returned."
        }
      },
      "id": "GoogleCloudContentwarehouseV1DocumentQuery"
    },
    "GoogleCloudContentwarehouseV1SetAclRequest": {
      "id": "GoogleCloudContentwarehouseV1SetAclRequest",
      "description": "Request message for DocumentService.SetAcl.",
      "type": "object",
      "properties": {
        "policy": {
          "description": "Required. REQUIRED: The complete policy to be applied to the `resource`. The size of the policy is limited to a few 10s of KB. This refers to an Identity and Access (IAM) policy, which specifies access controls for the Document. You can set ACL with condition for projects only. Supported operators are: `=`, `!=`, `\u003c`, `\u003c=`, `\u003e`, and `\u003e=` where the left of the operator is `DocumentSchemaId` or property name and the right of the operator is a number or a quoted string. You must escape backslash (\\\\) and quote (\\\") characters. Boolean expressions (AND/OR) are supported up to 3 levels of nesting (for example, \"((A AND B AND C) OR D) AND E\"), a maximum of 10 comparisons are allowed in the expression. The expression must be \u003c 6000 bytes in length. Sample condition: `\"DocumentSchemaId = \\\"some schema id\\\" OR SchemaId.floatPropertyName \u003e= 10\"`",
          "$ref": "GoogleIamV1Policy"
        },
        "requestMetadata": {
          "$ref": "GoogleCloudContentwarehouseV1RequestMetadata",
          "description": "The meta information collected about the end user, used to enforce access control for the service."
        },
        "projectOwner": {
          "description": "For Set Project ACL only. Authorization check for end user will be ignored when project_owner=true.",
          "type": "boolean"
        }
      }
    },
    "GoogleCloudContentwarehouseV1EnumArray": {
      "description": "Enum values.",
      "properties": {
        "values": {
          "description": "List of enum values.",
          "type": "array",
          "items": {
            "type": "string"
          }
        }
      },
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1EnumArray"
    },
    "GoogleIamV1Policy": {
      "id": "GoogleIamV1Policy",
      "description": "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 \u003c 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 \u003c 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/).",
      "type": "object",
      "properties": {
        "etag": {
          "type": "string",
          "description": "`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.",
          "format": "byte"
        },
        "version": {
          "description": "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).",
          "type": "integer",
          "format": "int32"
        },
        "bindings": {
          "description": "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`.",
          "type": "array",
          "items": {
            "$ref": "GoogleIamV1Binding"
          }
        },
        "auditConfigs": {
          "description": "Specifies cloud audit logging configuration for this policy.",
          "items": {
            "$ref": "GoogleIamV1AuditConfig"
          },
          "type": "array"
        }
      }
    },
    "GoogleCloudDocumentaiV1DocumentPageTableTableCell": {
      "id": "GoogleCloudDocumentaiV1DocumentPageTableTableCell",
      "description": "A cell representation inside the table.",
      "properties": {
        "colSpan": {
          "type": "integer",
          "format": "int32",
          "description": "How many columns this cell spans."
        },
        "detectedLanguages": {
          "description": "A list of detected languages together with confidence.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage"
          }
        },
        "rowSpan": {
          "description": "How many rows this cell spans.",
          "format": "int32",
          "type": "integer"
        },
        "layout": {
          "description": "Layout for TableCell.",
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout"
        }
      },
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1DataUpdateAction": {
      "description": "Represents the action responsible for properties update operations.",
      "id": "GoogleCloudContentwarehouseV1DataUpdateAction",
      "properties": {
        "entries": {
          "additionalProperties": {
            "type": "string"
          },
          "description": "Map of (K, V) -\u003e (valid name of the field, new value of the field) E.g., (\"age\", \"60\") entry triggers update of field age with a value of 60. If the field is not present then new entry is added. During update action execution, value strings will be casted to appropriate types.",
          "type": "object"
        }
      },
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1AddToFolderAction": {
      "properties": {
        "folders": {
          "description": "Names of the folder under which new document is to be added. Format: projects/{project_number}/locations/{location}/documents/{document_id}.",
          "items": {
            "type": "string"
          },
          "type": "array"
        }
      },
      "description": "Represents the action responsible for adding document under a folder.",
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1AddToFolderAction"
    },
    "GoogleCloudContentwarehouseV1InitializeProjectResponse": {
      "description": "Response message for projectService.InitializeProject",
      "id": "GoogleCloudContentwarehouseV1InitializeProjectResponse",
      "type": "object",
      "properties": {
        "message": {
          "description": "The message of the project initialization process.",
          "type": "string"
        },
        "state": {
          "enum": [
            "STATE_UNSPECIFIED",
            "SUCCEEDED",
            "FAILED",
            "CANCELLED",
            "RUNNING"
          ],
          "enumDescriptions": [
            "Clients should never see this.",
            "Finished project initialization without error.",
            "Finished project initialization with an error.",
            "Client canceled the LRO.",
            "Ask the customer to check the operation for results."
          ],
          "type": "string",
          "description": "The state of the project initialization process."
        }
      }
    },
    "GoogleCloudContentwarehouseV1ListLinkedTargetsRequest": {
      "properties": {
        "requestMetadata": {
          "description": "The meta information collected about the document creator, used to enforce access control for the service.",
          "$ref": "GoogleCloudContentwarehouseV1RequestMetadata"
        }
      },
      "id": "GoogleCloudContentwarehouseV1ListLinkedTargetsRequest",
      "description": "Request message for DocumentLinkService.ListLinkedTargets.",
      "type": "object"
    },
    "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage": {
      "type": "object",
      "properties": {
        "confidence": {
          "type": "number",
          "format": "float",
          "description": "Confidence of detected language. Range `[0, 1]`."
        },
        "languageCode": {
          "type": "string",
          "description": "The [BCP-47 language code](https://www.unicode.org/reports/tr35/#Unicode_locale_identifier), such as `en-US` or `sr-Latn`."
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage",
      "description": "Detected language for a structural component."
    },
    "GoogleCloudContentwarehouseV1DateTimeTypeOptions": {
      "type": "object",
      "properties": {},
      "id": "GoogleCloudContentwarehouseV1DateTimeTypeOptions",
      "description": "Configurations for a date time property."
    },
    "CloudAiPlatformTenantresourceServiceAccountIdentity": {
      "description": "The identity to configure a service account.",
      "id": "CloudAiPlatformTenantresourceServiceAccountIdentity",
      "type": "object",
      "properties": {
        "tag": {
          "description": "Input/Output [Optional]. The tag that configures the service account, as defined in google3/configs/production/cdpush/acl-zanzibar-cloud-prod/activation_grants/activation_grants.gcl. Note: The default P4 service account has the empty tag.",
          "type": "string"
        },
        "serviceAccountEmail": {
          "description": "Output only. The service account email that has been created.",
          "type": "string"
        }
      }
    },
    "GoogleCloudDocumentaiV1DocumentPageBlock": {
      "type": "object",
      "description": "A block has a set of lines (collected into paragraphs) that have a common line-spacing and orientation.",
      "properties": {
        "provenance": {
          "description": "The history of this annotation.",
          "$ref": "GoogleCloudDocumentaiV1DocumentProvenance",
          "deprecated": true
        },
        "layout": {
          "description": "Layout for Block.",
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout"
        },
        "detectedLanguages": {
          "type": "array",
          "description": "A list of detected languages together with confidence.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage"
          }
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentPageBlock"
    },
    "GoogleCloudContentwarehouseV1UpdateDocumentMetadata": {
      "description": "Metadata object for UpdateDocument request (currently empty).",
      "properties": {},
      "id": "GoogleCloudContentwarehouseV1UpdateDocumentMetadata",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1HistogramQueryPropertyNameFilter": {
      "id": "GoogleCloudContentwarehouseV1HistogramQueryPropertyNameFilter",
      "type": "object",
      "properties": {
        "yAxis": {
          "enum": [
            "HISTOGRAM_YAXIS_DOCUMENT",
            "HISTOGRAM_YAXIS_PROPERTY"
          ],
          "type": "string",
          "description": "By default, the y_axis is HISTOGRAM_YAXIS_DOCUMENT if this field is not set.",
          "enumDescriptions": [
            "Count the documents per property name.",
            "Count the properties per property name."
          ]
        },
        "propertyNames": {
          "items": {
            "type": "string"
          },
          "description": "It is optional. It will perform histogram for all the property names if it is not set. The properties need to be defined with the is_filterable flag set to true and the name of the property should be in the format: \"schemaId.propertyName\". The property needs to be defined in the schema. Example: the schema id is abc. Then the name of property for property MORTGAGE_TYPE will be \"abc.MORTGAGE_TYPE\".",
          "type": "array"
        },
        "documentSchemas": {
          "items": {
            "type": "string"
          },
          "type": "array",
          "description": "This filter specifies the exact document schema(s) Document.document_schema_name to run histogram query against. It is optional. It will perform histogram for property names for all the document schemas if it is not set. At most 10 document schema names are allowed. Format: projects/{project_number}/locations/{location}/documentSchemas/{document_schema_id}."
        }
      }
    },
    "GoogleCloudContentwarehouseV1AccessControlAction": {
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1AccessControlAction",
      "properties": {
        "operationType": {
          "type": "string",
          "description": "Identifies the type of operation.",
          "enumDescriptions": [
            "The unknown operation type.",
            "Adds newly given policy bindings in the existing bindings list.",
            "Removes newly given policy bindings from the existing bindings list.",
            "Replaces existing policy bindings with the given policy binding list"
          ],
          "enum": [
            "UNKNOWN",
            "ADD_POLICY_BINDING",
            "REMOVE_POLICY_BINDING",
            "REPLACE_POLICY_BINDING"
          ]
        },
        "policy": {
          "description": "Represents the new policy from which bindings are added, removed or replaced based on the type of the operation. the policy is limited to a few 10s of KB.",
          "$ref": "GoogleIamV1Policy"
        }
      },
      "description": "Represents the action responsible for access control list management operations."
    },
    "GoogleCloudContentwarehouseV1ListLinkedSourcesRequest": {
      "properties": {
        "pageToken": {
          "description": "A page token, received from a previous `ListLinkedSources` call. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to `ListLinkedSources` must match the call that provided the page token.",
          "type": "string"
        },
        "pageSize": {
          "type": "integer",
          "description": "The maximum number of document-links to return. The service may return fewer than this value. If unspecified, at most 50 document-links will be returned. The maximum value is 1000; values above 1000 will be coerced to 1000.",
          "format": "int32"
        },
        "requestMetadata": {
          "description": "The meta information collected about the document creator, used to enforce access control for the service.",
          "$ref": "GoogleCloudContentwarehouseV1RequestMetadata"
        }
      },
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1ListLinkedSourcesRequest",
      "description": "Response message for DocumentLinkService.ListLinkedSources."
    },
    "GoogleCloudContentwarehouseV1IngestPipelineConfig": {
      "type": "object",
      "description": "The ingestion pipeline config.",
      "properties": {
        "documentAclPolicy": {
          "description": "The document level acl policy config. This refers to an Identity and Access (IAM) policy, which specifies access controls for all documents ingested by the pipeline. The role and members under the policy needs to be specified. The following roles are supported for document level acl control: * roles/contentwarehouse.documentAdmin * roles/contentwarehouse.documentEditor * roles/contentwarehouse.documentViewer The following members are supported for document level acl control: * user:user-email@example.com * group:group-email@example.com Note that for documents searched with LLM, only single level user or group acl check is supported.",
          "$ref": "GoogleIamV1Policy"
        },
        "enableDocumentTextExtraction": {
          "type": "boolean",
          "description": "The document text extraction enabled flag. If the flag is set to true, DWH will perform text extraction on the raw document."
        },
        "folder": {
          "type": "string",
          "description": "Optional. The name of the folder to which all ingested documents will be linked during ingestion process. Format is `projects/{project}/locations/{location}/documents/{folder_id}`"
        },
        "cloudFunction": {
          "description": "The Cloud Function resource name. The Cloud Function needs to live inside consumer project and is accessible to Document AI Warehouse P4SA. Only Cloud Functions V2 is supported. Cloud function execution should complete within 5 minutes or this file ingestion may fail due to timeout. Format: `https://{region}-{project_id}.cloudfunctions.net/{cloud_function}` The following keys are available the request json payload. * display_name * properties * plain_text * reference_id * document_schema_name * raw_document_path * raw_document_file_type The following keys from the cloud function json response payload will be ingested to the Document AI Warehouse as part of Document proto content and/or related information. The original values will be overridden if any key is present in the response. * display_name * properties * plain_text * document_acl_policy * folder",
          "type": "string"
        }
      },
      "id": "GoogleCloudContentwarehouseV1IngestPipelineConfig"
    },
    "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutPageSpan": {
      "type": "object",
      "description": "Represents where the block starts and ends in the document.",
      "id": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutPageSpan",
      "properties": {
        "pageStart": {
          "format": "int32",
          "description": "Page where block starts in the document.",
          "type": "integer"
        },
        "pageEnd": {
          "format": "int32",
          "description": "Page where block ends in the document.",
          "type": "integer"
        }
      }
    },
    "GoogleCloudContentwarehouseV1HistogramQueryResult": {
      "type": "object",
      "description": "Histogram result that matches HistogramQuery specified in searches.",
      "id": "GoogleCloudContentwarehouseV1HistogramQueryResult",
      "properties": {
        "histogram": {
          "type": "object",
          "description": "A map from the values of the facet associated with distinct values to the number of matching entries with corresponding value. The key format is: * (for string histogram) string values stored in the field.",
          "additionalProperties": {
            "type": "string",
            "format": "int64"
          }
        },
        "histogramQuery": {
          "description": "Requested histogram expression.",
          "type": "string"
        }
      }
    },
    "GoogleCloudContentwarehouseV1TimestampValue": {
      "type": "object",
      "properties": {
        "textValue": {
          "type": "string",
          "description": "The string must represent a valid instant in UTC and is parsed using java.time.format.DateTimeFormatter.ISO_INSTANT. e.g. \"2013-09-29T18:46:19Z\""
        },
        "timestampValue": {
          "format": "google-datetime",
          "type": "string",
          "description": "Timestamp value"
        }
      },
      "id": "GoogleCloudContentwarehouseV1TimestampValue",
      "description": "Timestamp value type."
    },
    "GoogleCloudContentwarehouseV1RemoveFromFolderAction": {
      "properties": {
        "folder": {
          "type": "string",
          "description": "Name of the folder under which new document is to be added. Format: projects/{project_number}/locations/{location}/documents/{document_id}."
        },
        "condition": {
          "type": "string",
          "description": "Condition of the action to be executed."
        }
      },
      "description": "Represents the action responsible for remove a document from a specific folder.",
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1RemoveFromFolderAction"
    },
    "GoogleIamV1AuditLogConfig": {
      "id": "GoogleIamV1AuditLogConfig",
      "properties": {
        "exemptedMembers": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "Specifies the identities that do not cause logging for this type of permission. Follows the same format of Binding.members."
        },
        "logType": {
          "enumDescriptions": [
            "Default case. Should never be this.",
            "Admin reads. Example: CloudIAM getIamPolicy",
            "Data writes. Example: CloudSQL Users create",
            "Data reads. Example: CloudSQL Users list"
          ],
          "description": "The log type that this config enables.",
          "enum": [
            "LOG_TYPE_UNSPECIFIED",
            "ADMIN_READ",
            "DATA_WRITE",
            "DATA_READ"
          ],
          "type": "string"
        }
      },
      "type": "object",
      "description": "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."
    },
    "GoogleApiServiceconsumermanagementV1BillingConfig": {
      "id": "GoogleApiServiceconsumermanagementV1BillingConfig",
      "description": "Describes the billing configuration for a new tenant project.",
      "properties": {
        "billingAccount": {
          "type": "string",
          "description": "Name of the billing account. For example `billingAccounts/012345-567890-ABCDEF`."
        }
      },
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1DeleteDocumentLinkRequest": {
      "description": "Request message for DocumentLinkService.DeleteDocumentLink.",
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1DeleteDocumentLinkRequest",
      "properties": {
        "requestMetadata": {
          "description": "The meta information collected about the document creator, used to enforce access control for the service.",
          "$ref": "GoogleCloudContentwarehouseV1RequestMetadata"
        }
      }
    },
    "GoogleCloudContentwarehouseV1SynonymSetSynonym": {
      "type": "object",
      "properties": {
        "words": {
          "items": {
            "type": "string"
          },
          "type": "array",
          "description": "For example: sale, invoice, bill, order"
        }
      },
      "description": "Represents a list of words given by the customer All these words are synonyms of each other.",
      "id": "GoogleCloudContentwarehouseV1SynonymSetSynonym"
    },
    "GoogleTypeDateTime": {
      "description": "Represents civil time (or occasionally physical time). This type can represent a civil time in one of a few possible ways: * When utc_offset is set and time_zone is unset: a civil time on a calendar day with a particular offset from UTC. * When time_zone is set and utc_offset is unset: a civil time on a calendar day in a particular time zone. * When neither time_zone nor utc_offset is set: a civil time on a calendar day in local time. The date is relative to the Proleptic Gregorian Calendar. If year, month, or day are 0, the DateTime is considered not to have a specific year, month, or day respectively. This type may also be used to represent a physical time if all the date and time fields are set and either case of the `time_offset` oneof is set. Consider using `Timestamp` message for physical time instead. If your use case also would like to store the user's timezone, that can be done in another field. This type is more flexible than some applications may want. Make sure to document and validate your application's limitations.",
      "properties": {
        "timeZone": {
          "description": "Time zone.",
          "$ref": "GoogleTypeTimeZone"
        },
        "hours": {
          "type": "integer",
          "description": "Optional. Hours of day in 24 hour format. Should be from 0 to 23, defaults to 0 (midnight). An API may choose to allow the value \"24:00:00\" for scenarios like business closing time.",
          "format": "int32"
        },
        "nanos": {
          "description": "Optional. Fractions of seconds in nanoseconds. Must be from 0 to 999,999,999, defaults to 0.",
          "type": "integer",
          "format": "int32"
        },
        "seconds": {
          "type": "integer",
          "format": "int32",
          "description": "Optional. Seconds of minutes of the time. Must normally be from 0 to 59, defaults to 0. An API may allow the value 60 if it allows leap-seconds."
        },
        "month": {
          "description": "Optional. Month of year. Must be from 1 to 12, or 0 if specifying a datetime without a month.",
          "format": "int32",
          "type": "integer"
        },
        "year": {
          "description": "Optional. Year of date. Must be from 1 to 9999, or 0 if specifying a datetime without a year.",
          "type": "integer",
          "format": "int32"
        },
        "day": {
          "type": "integer",
          "description": "Optional. Day of month. Must be from 1 to 31 and valid for the year and month, or 0 if specifying a datetime without a day.",
          "format": "int32"
        },
        "utcOffset": {
          "description": "UTC offset. Must be whole seconds, between -18 hours and +18 hours. For example, a UTC offset of -4:00 would be represented as { seconds: -14400 }.",
          "format": "google-duration",
          "type": "string"
        },
        "minutes": {
          "description": "Optional. Minutes of hour of day. Must be from 0 to 59, defaults to 0.",
          "format": "int32",
          "type": "integer"
        }
      },
      "type": "object",
      "id": "GoogleTypeDateTime"
    },
    "CloudAiPlatformTenantresourceGcsBucketConfig": {
      "description": "The identity to configure a GCS bucket.",
      "type": "object",
      "properties": {
        "admins": {
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "bucketName": {
          "type": "string",
          "description": "Input/Output [Optional]. The name of a GCS bucket with max length of 63 chars. If not set, a random UUID will be generated as bucket name."
        },
        "entityName": {
          "type": "string",
          "description": "Input/Output [Optional]. Only needed for per-entity tenant GCP resources. During Deprovision API, the on-demand deletion will only cover the tenant GCP resources with the specified entity name."
        },
        "viewers": {
          "items": {
            "type": "string"
          },
          "type": "array",
          "description": "Input/Output [Required]. IAM roles (viewer/admin) put on the bucket."
        },
        "ttlDays": {
          "type": "integer",
          "description": "Input/Output [Optional]. Only needed when the content in bucket need to be garbage collected within some amount of days.",
          "format": "int32"
        },
        "kmsKeyReference": {
          "description": "Input/Output [Optional]. The KMS key name or the KMS grant name used for CMEK encryption. Only set this field when provisioning new GCS bucket. For existing GCS bucket, this field will be ignored because CMEK re-encryption is not supported.",
          "type": "string"
        }
      },
      "id": "CloudAiPlatformTenantresourceGcsBucketConfig"
    },
    "GoogleCloudDocumentaiV1DocumentPageLine": {
      "type": "object",
      "description": "A collection of tokens that a human would perceive as a line. Does not cross column boundaries, can be horizontal, vertical, etc.",
      "properties": {
        "layout": {
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout",
          "description": "Layout for Line."
        },
        "detectedLanguages": {
          "description": "A list of detected languages together with confidence.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage"
          }
        },
        "provenance": {
          "$ref": "GoogleCloudDocumentaiV1DocumentProvenance",
          "description": "The history of this annotation.",
          "deprecated": true
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentPageLine"
    },
    "GoogleCloudDocumentaiV1DocumentStyle": {
      "type": "object",
      "description": "Annotation for common text style attributes. This adheres to CSS conventions as much as possible.",
      "id": "GoogleCloudDocumentaiV1DocumentStyle",
      "properties": {
        "textStyle": {
          "description": "[Text style](https://www.w3schools.com/cssref/pr_font_font-style.asp). Possible values are `normal`, `italic`, and `oblique`.",
          "type": "string"
        },
        "fontWeight": {
          "type": "string",
          "description": "[Font weight](https://www.w3schools.com/cssref/pr_font_weight.asp). Possible values are `normal`, `bold`, `bolder`, and `lighter`."
        },
        "fontFamily": {
          "type": "string",
          "description": "Font family such as `Arial`, `Times New Roman`. https://www.w3schools.com/cssref/pr_font_font-family.asp"
        },
        "backgroundColor": {
          "description": "Text background color.",
          "$ref": "GoogleTypeColor"
        },
        "textDecoration": {
          "type": "string",
          "description": "[Text decoration](https://www.w3schools.com/cssref/pr_text_text-decoration.asp). Follows CSS standard. "
        },
        "textAnchor": {
          "$ref": "GoogleCloudDocumentaiV1DocumentTextAnchor",
          "description": "Text anchor indexing into the Document.text."
        },
        "fontSize": {
          "$ref": "GoogleCloudDocumentaiV1DocumentStyleFontSize",
          "description": "Font size."
        },
        "color": {
          "$ref": "GoogleTypeColor",
          "description": "Text color."
        }
      }
    },
    "GoogleCloudContentwarehouseV1ProcessorInfo": {
      "type": "object",
      "properties": {
        "schemaName": {
          "description": "The Document schema resource name. All documents processed by this processor will use this schema. Format: projects/{project_number}/locations/{location}/documentSchemas/{document_schema_id}.",
          "type": "string"
        },
        "documentType": {
          "type": "string",
          "description": "The processor will process the documents with this document type."
        },
        "processorName": {
          "description": "The processor resource name. Format is `projects/{project}/locations/{location}/processors/{processor}`, or `projects/{project}/locations/{location}/processors/{processor}/processorVersions/{processorVersion}`",
          "type": "string"
        }
      },
      "id": "GoogleCloudContentwarehouseV1ProcessorInfo",
      "description": "The DocAI processor information."
    },
    "GoogleCloudContentwarehouseV1InvalidRule": {
      "id": "GoogleCloudContentwarehouseV1InvalidRule",
      "properties": {
        "error": {
          "description": "Validation error on a parsed expression.",
          "type": "string"
        },
        "rule": {
          "description": "Triggered rule.",
          "$ref": "GoogleCloudContentwarehouseV1Rule"
        }
      },
      "description": "A triggered rule that failed the validation check(s) after parsing.",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1FileTypeFilter": {
      "description": "Filter for the specific types of documents returned.",
      "properties": {
        "fileType": {
          "description": "The type of files to return.",
          "enum": [
            "FILE_TYPE_UNSPECIFIED",
            "ALL",
            "FOLDER",
            "DOCUMENT",
            "ROOT_FOLDER"
          ],
          "type": "string",
          "enumDescriptions": [
            "Default document type. If set, disables the filter.",
            "Returns all document types, including folders.",
            "Returns only folders.",
            "Returns only non-folder documents.",
            "Returns only root folders"
          ]
        }
      },
      "id": "GoogleCloudContentwarehouseV1FileTypeFilter",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1RuleEngineOutput": {
      "properties": {
        "ruleEvaluatorOutput": {
          "$ref": "GoogleCloudContentwarehouseV1RuleEvaluatorOutput",
          "description": "Output from Rule Evaluator containing matched, unmatched and invalid rules."
        },
        "actionExecutorOutput": {
          "description": "Output from Action Executor containing rule and corresponding actions execution result.",
          "$ref": "GoogleCloudContentwarehouseV1ActionExecutorOutput"
        },
        "documentName": {
          "type": "string",
          "description": "Name of the document against which the rules and actions were evaluated."
        }
      },
      "id": "GoogleCloudContentwarehouseV1RuleEngineOutput",
      "description": "Records the output of Rule Engine including rule evaluation and actions result.",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1MergeFieldsOptions": {
      "properties": {
        "replaceRepeatedFields": {
          "type": "boolean",
          "description": "When merging repeated fields, the default behavior is to append entries from the source repeated field to the destination repeated field. If you instead want to keep only the entries from the source repeated field, set this flag to true. If you want to replace a repeated field within a message field on the destination message, you must set both replace_repeated_fields and replace_message_fields to true, otherwise the repeated fields will be appended."
        },
        "replaceMessageFields": {
          "description": "When merging message fields, the default behavior is to merge the content of two message fields together. If you instead want to use the field from the source message to replace the corresponding field in the destination message, set this flag to true. When this flag is set, specified submessage fields that are missing in source will be cleared in destination.",
          "type": "boolean"
        }
      },
      "description": "Options for merging updated fields.",
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1MergeFieldsOptions"
    },
    "GoogleCloudContentwarehouseV1DocumentReference": {
      "description": "References to the documents.",
      "properties": {
        "documentIsLegalHoldFolder": {
          "type": "boolean",
          "description": "Document is a folder with legal hold."
        },
        "createTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "Output only. The time when the document is created.",
          "readOnly": true
        },
        "documentIsRetentionFolder": {
          "description": "Document is a folder with retention policy.",
          "type": "boolean"
        },
        "displayName": {
          "description": "display_name of the referenced document; this name does not need to be consistent to the display_name in the Document proto, depending on the ACL constraint.",
          "type": "string"
        },
        "snippet": {
          "type": "string",
          "description": "Stores the subset of the referenced document's content. This is useful to allow user peek the information of the referenced document."
        },
        "deleteTime": {
          "format": "google-datetime",
          "description": "Output only. The time when the document is deleted.",
          "type": "string",
          "readOnly": true
        },
        "documentIsFolder": {
          "description": "The document type of the document being referenced.",
          "type": "boolean"
        },
        "documentName": {
          "description": "Required. Name of the referenced document.",
          "type": "string"
        },
        "updateTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "Output only. The time when the document is last updated.",
          "readOnly": true
        }
      },
      "id": "GoogleCloudContentwarehouseV1DocumentReference",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1DeleteDocumentRequest": {
      "properties": {
        "requestMetadata": {
          "description": "The meta information collected about the end user, used to enforce access control for the service.",
          "$ref": "GoogleCloudContentwarehouseV1RequestMetadata"
        }
      },
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1DeleteDocumentRequest",
      "description": "Request message for DocumentService.DeleteDocument."
    },
    "GoogleCloudContentwarehouseV1FetchAclResponse": {
      "description": "Response message for DocumentService.FetchAcl.",
      "properties": {
        "metadata": {
          "description": "Additional information for the API invocation, such as the request tracking id.",
          "$ref": "GoogleCloudContentwarehouseV1ResponseMetadata"
        },
        "policy": {
          "$ref": "GoogleIamV1Policy",
          "description": "The IAM policy."
        }
      },
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1FetchAclResponse"
    },
    "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunk": {
      "properties": {
        "pageSpan": {
          "$ref": "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunkChunkPageSpan",
          "description": "Page span of the chunk."
        },
        "content": {
          "description": "Text content of the chunk.",
          "type": "string"
        },
        "pageFooters": {
          "description": "Page footers associated with the chunk.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunkChunkPageFooter"
          }
        },
        "sourceBlockIds": {
          "description": "Unused.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "chunkId": {
          "type": "string",
          "description": "ID of the chunk."
        },
        "pageHeaders": {
          "description": "Page headers associated with the chunk.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunkChunkPageHeader"
          }
        }
      },
      "description": "Represents a chunk.",
      "id": "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunk",
      "type": "object"
    },
    "GoogleCloudDocumentaiV1DocumentTextAnchor": {
      "id": "GoogleCloudDocumentaiV1DocumentTextAnchor",
      "type": "object",
      "properties": {
        "content": {
          "type": "string",
          "description": "Contains the content of the text span so that users do not have to look it up in the text_segments. It is always populated for formFields."
        },
        "textSegments": {
          "type": "array",
          "description": "The text segments from the Document.text.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentTextAnchorTextSegment"
          }
        }
      },
      "description": "Text reference indexing into the Document.text."
    },
    "GoogleCloudDocumentaiV1DocumentStyleFontSize": {
      "description": "Font size with unit.",
      "type": "object",
      "id": "GoogleCloudDocumentaiV1DocumentStyleFontSize",
      "properties": {
        "size": {
          "description": "Font size for the text.",
          "format": "float",
          "type": "number"
        },
        "unit": {
          "type": "string",
          "description": "Unit for the font size. Follows CSS naming (such as `in`, `px`, and `pt`)."
        }
      }
    },
    "GoogleTypeMoney": {
      "type": "object",
      "properties": {
        "currencyCode": {
          "description": "The three-letter currency code defined in ISO 4217.",
          "type": "string"
        },
        "units": {
          "format": "int64",
          "description": "The whole units of the amount. For example if `currencyCode` is `\"USD\"`, then 1 unit is one US dollar.",
          "type": "string"
        },
        "nanos": {
          "type": "integer",
          "description": "Number of nano (10^-9) units of the amount. The value must be between -999,999,999 and +999,999,999 inclusive. If `units` is positive, `nanos` must be positive or zero. If `units` is zero, `nanos` can be positive, zero, or negative. If `units` is negative, `nanos` must be negative or zero. For example $-1.75 is represented as `units`=-1 and `nanos`=-750,000,000.",
          "format": "int32"
        }
      },
      "description": "Represents an amount of money with its currency type.",
      "id": "GoogleTypeMoney"
    },
    "GoogleCloudDocumentaiV1DocumentRevision": {
      "type": "object",
      "properties": {
        "createTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "The time that the revision was created, internally generated by doc proto storage at the time of create."
        },
        "humanReview": {
          "$ref": "GoogleCloudDocumentaiV1DocumentRevisionHumanReview",
          "description": "Human Review information of this revision."
        },
        "agent": {
          "description": "If the change was made by a person specify the name or id of that person.",
          "type": "string"
        },
        "parentIds": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "The revisions that this revision is based on. Must include all the ids that have anything to do with this revision - eg. there are `provenance.parent.revision` fields that index into this field."
        },
        "parent": {
          "type": "array",
          "deprecated": true,
          "items": {
            "format": "int32",
            "type": "integer"
          },
          "description": "The revisions that this revision is based on. This can include one or more parent (when documents are merged.) This field represents the index into the `revisions` field."
        },
        "processor": {
          "description": "If the annotation was made by processor identify the processor by its resource name.",
          "type": "string"
        },
        "id": {
          "description": "Id of the revision, internally generated by doc proto storage. Unique within the context of the document.",
          "type": "string"
        }
      },
      "description": "Contains past or forward revisions of this document.",
      "id": "GoogleCloudDocumentaiV1DocumentRevision"
    },
    "GoogleCloudContentwarehouseV1WeightedSchemaProperty": {
      "id": "GoogleCloudContentwarehouseV1WeightedSchemaProperty",
      "type": "object",
      "description": "Specifies the schema property name.",
      "properties": {
        "documentSchemaName": {
          "description": "The document schema name.",
          "type": "string"
        },
        "propertyNames": {
          "description": "The property definition names in the schema.",
          "items": {
            "type": "string"
          },
          "type": "array"
        }
      }
    },
    "GoogleCloudContentwarehouseV1QAResult": {
      "properties": {
        "confidenceScore": {
          "format": "float",
          "description": "The calibrated confidence score for this document, in the range [0., 1.]. This represents the confidence level for whether the returned document and snippet answers the user's query.",
          "type": "number"
        },
        "highlights": {
          "type": "array",
          "description": "Highlighted sections in the snippet.",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1QAResultHighlight"
          }
        }
      },
      "type": "object",
      "description": "Additional result info for the question-answering feature.",
      "id": "GoogleCloudContentwarehouseV1QAResult"
    },
    "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunkChunkPageFooter": {
      "description": "Represents the page footer associated with the chunk.",
      "type": "object",
      "id": "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunkChunkPageFooter",
      "properties": {
        "text": {
          "type": "string",
          "description": "Footer in text format."
        },
        "pageSpan": {
          "description": "Page span of the footer.",
          "$ref": "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunkChunkPageSpan"
        }
      }
    },
    "GoogleCloudContentwarehouseV1RuleEvaluatorOutput": {
      "id": "GoogleCloudContentwarehouseV1RuleEvaluatorOutput",
      "properties": {
        "triggeredRules": {
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1Rule"
          },
          "type": "array",
          "description": "List of rules fetched from database for the given request trigger type."
        },
        "invalidRules": {
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1InvalidRule"
          },
          "description": "A subset of triggered rules that failed the validation check(s) after parsing.",
          "type": "array"
        },
        "matchedRules": {
          "description": "A subset of triggered rules that are evaluated true for a given request.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1Rule"
          }
        }
      },
      "description": "Represents the output of the Rule Evaluator.",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1RunPipelineMetadataProcessWithDocAiPipelineMetadata": {
      "id": "GoogleCloudContentwarehouseV1RunPipelineMetadataProcessWithDocAiPipelineMetadata",
      "type": "object",
      "properties": {
        "documents": {
          "items": {
            "type": "string"
          },
          "type": "array",
          "description": "The input list of all the resource names of the documents to be processed."
        },
        "processorInfo": {
          "$ref": "GoogleCloudContentwarehouseV1ProcessorInfo",
          "description": "The DocAI processor to process the documents with."
        }
      },
      "description": "The metadata message for Process-with-DocAi pipeline."
    },
    "GoogleCloudDocumentaiV1DocumentPageImageQualityScores": {
      "description": "Image quality scores for the page image.",
      "properties": {
        "qualityScore": {
          "format": "float",
          "type": "number",
          "description": "The overall quality score. Range `[0, 1]` where `1` is perfect quality."
        },
        "detectedDefects": {
          "description": "A list of detected defects.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageImageQualityScoresDetectedDefect"
          }
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentPageImageQualityScores",
      "type": "object"
    },
    "GoogleTypePostalAddress": {
      "type": "object",
      "id": "GoogleTypePostalAddress",
      "properties": {
        "recipients": {
          "description": "Optional. The recipient at the address. This field may, under certain circumstances, contain multiline information. For example, it might contain \"care of\" information.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "administrativeArea": {
          "type": "string",
          "description": "Optional. Highest administrative subdivision which is used for postal addresses of a country or region. For example, this can be a state, a province, an oblast, or a prefecture. Specifically, for Spain this is the province and not the autonomous community (For example \"Barcelona\" and not \"Catalonia\"). Many countries don't use an administrative area in postal addresses. For example in Switzerland this should be left unpopulated."
        },
        "regionCode": {
          "type": "string",
          "description": "Required. CLDR region code of the country/region of the address. This is never inferred and it is up to the user to ensure the value is correct. See https://cldr.unicode.org/ and https://www.unicode.org/cldr/charts/30/supplemental/territory_information.html for details. Example: \"CH\" for Switzerland."
        },
        "languageCode": {
          "type": "string",
          "description": "Optional. BCP-47 language code of the contents of this address (if known). This is often the UI language of the input form or is expected to match one of the languages used in the address' country/region, or their transliterated equivalents. This can affect formatting in certain countries, but is not critical to the correctness of the data and will never affect any validation or other non-formatting related operations. If this value is not known, it should be omitted (rather than specifying a possibly incorrect default). Examples: \"zh-Hant\", \"ja\", \"ja-Latn\", \"en\"."
        },
        "revision": {
          "description": "The schema revision of the `PostalAddress`. This must be set to 0, which is the latest revision. All new revisions **must** be backward compatible with old revisions.",
          "format": "int32",
          "type": "integer"
        },
        "locality": {
          "description": "Optional. Generally refers to the city/town portion of the address. Examples: US city, IT comune, UK post town. In regions of the world where localities are not well defined or do not fit into this structure well, leave locality empty and use address_lines.",
          "type": "string"
        },
        "postalCode": {
          "type": "string",
          "description": "Optional. Postal code of the address. Not all countries use or require postal codes to be present, but where they are used, they may trigger additional validation with other parts of the address (For example state/zip validation in the U.S.A.)."
        },
        "sublocality": {
          "description": "Optional. Sublocality of the address. For example, this can be neighborhoods, boroughs, districts.",
          "type": "string"
        },
        "addressLines": {
          "type": "array",
          "description": "Unstructured address lines describing the lower levels of an address. Because values in address_lines do not have type information and may sometimes contain multiple values in a single field (For example \"Austin, TX\"), it is important that the line order is clear. The order of address lines should be \"envelope order\" for the country/region of the address. In places where this can vary (For example Japan), address_language is used to make it explicit (For example \"ja\" for large-to-small ordering and \"ja-Latn\" or \"en\" for small-to-large). This way, the most specific line of an address can be selected based on the language. The minimum permitted structural representation of an address consists of a region_code with all remaining information placed in the address_lines. It would be possible to format such an address very approximately without geocoding, but no semantic reasoning could be made about any of the address components until it was at least partially resolved. Creating an address only containing a region_code and address_lines, and then geocoding is the recommended way to handle completely unstructured addresses (as opposed to guessing which parts of the address should be localities or administrative areas).",
          "items": {
            "type": "string"
          }
        },
        "sortingCode": {
          "description": "Optional. Additional, country-specific, sorting code. This is not used in most regions. Where it is used, the value is either a string like \"CEDEX\", optionally followed by a number (For example \"CEDEX 7\"), or just a number alone, representing the \"sector code\" (Jamaica), \"delivery area indicator\" (Malawi) or \"post office indicator\" (For example Côte d'Ivoire).",
          "type": "string"
        },
        "organization": {
          "description": "Optional. The name of the organization at the address.",
          "type": "string"
        }
      },
      "description": "Represents a postal address. For example for postal delivery or payments addresses. Given a postal address, a postal service can deliver items to a premise, P.O. Box or similar. It is not intended to model geographical locations (roads, towns, mountains). In typical usage an address would be created by user input or from importing existing data, depending on the type of process. Advice on address input / editing: - Use an internationalization-ready address widget such as https://github.com/google/libaddressinput) - Users should not be presented with UI elements for input or editing of fields outside countries where that field is used. For more guidance on how to use this schema, see: https://support.google.com/business/answer/6397478"
    },
    "GoogleTypeExpr": {
      "id": "GoogleTypeExpr",
      "type": "object",
      "description": "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() \u003c 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.",
      "properties": {
        "description": {
          "type": "string",
          "description": "Optional. Description of the expression. This is a longer text which describes the expression, e.g. when hovered over it in a UI."
        },
        "location": {
          "description": "Optional. String indicating the location of the expression for error reporting, e.g. a file name and a position in the file.",
          "type": "string"
        },
        "title": {
          "description": "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.",
          "type": "string"
        },
        "expression": {
          "description": "Textual representation of an expression in Common Expression Language syntax.",
          "type": "string"
        }
      }
    },
    "GoogleCloudContentwarehouseV1Property": {
      "id": "GoogleCloudContentwarehouseV1Property",
      "description": "Property of a document.",
      "properties": {
        "name": {
          "description": "Required. Must match the name of a PropertyDefinition in the DocumentSchema.",
          "type": "string"
        },
        "enumValues": {
          "description": "Enum property values.",
          "$ref": "GoogleCloudContentwarehouseV1EnumArray"
        },
        "dateTimeValues": {
          "$ref": "GoogleCloudContentwarehouseV1DateTimeArray",
          "description": "Date time property values. It is not supported by CMEK compliant deployment."
        },
        "integerValues": {
          "description": "Integer property values.",
          "$ref": "GoogleCloudContentwarehouseV1IntegerArray"
        },
        "propertyValues": {
          "description": "Nested structured data property values.",
          "$ref": "GoogleCloudContentwarehouseV1PropertyArray"
        },
        "textValues": {
          "description": "String/text property values.",
          "$ref": "GoogleCloudContentwarehouseV1TextArray"
        },
        "floatValues": {
          "$ref": "GoogleCloudContentwarehouseV1FloatArray",
          "description": "Float property values."
        },
        "mapProperty": {
          "description": "Map property values.",
          "$ref": "GoogleCloudContentwarehouseV1MapProperty"
        },
        "timestampValues": {
          "description": "Timestamp property values. It is not supported by CMEK compliant deployment.",
          "$ref": "GoogleCloudContentwarehouseV1TimestampArray"
        }
      },
      "type": "object"
    },
    "GoogleCloudDocumentaiV1DocumentPageMatrix": {
      "properties": {
        "rows": {
          "description": "Number of rows in the matrix.",
          "format": "int32",
          "type": "integer"
        },
        "type": {
          "description": "This encodes information about what data type the matrix uses. For example, 0 (CV_8U) is an unsigned 8-bit image. For the full list of OpenCV primitive data types, please refer to https://docs.opencv.org/4.3.0/d1/d1b/group__core__hal__interface.html",
          "format": "int32",
          "type": "integer"
        },
        "cols": {
          "format": "int32",
          "description": "Number of columns in the matrix.",
          "type": "integer"
        },
        "data": {
          "type": "string",
          "format": "byte",
          "description": "The matrix data."
        }
      },
      "description": "Representation for transformation matrix, intended to be compatible and used with OpenCV format for image manipulation.",
      "type": "object",
      "id": "GoogleCloudDocumentaiV1DocumentPageMatrix"
    },
    "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTextBlock": {
      "id": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTextBlock",
      "type": "object",
      "description": "Represents a text type block.",
      "properties": {
        "type": {
          "description": "Type of the text in the block. Available options are: `paragraph`, `subtitle`, `heading-1`, `heading-2`, `heading-3`, `heading-4`, `heading-5`, `header`, `footer`.",
          "type": "string"
        },
        "blocks": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlock"
          },
          "description": "A text block could further have child blocks. Repeated blocks support further hierarchies and nested blocks."
        },
        "text": {
          "description": "Text content stored in the block.",
          "type": "string"
        }
      }
    },
    "GoogleCloudContentwarehouseV1TimeFilter": {
      "type": "object",
      "properties": {
        "timeField": {
          "type": "string",
          "description": "Specifies which time field to filter documents on. Defaults to TimeField.UPLOAD_TIME.",
          "enum": [
            "TIME_FIELD_UNSPECIFIED",
            "CREATE_TIME",
            "UPDATE_TIME",
            "DISPOSITION_TIME"
          ],
          "enumDescriptions": [
            "Default value.",
            "Earliest document create time.",
            "Latest document update time.",
            "Time when document becomes mutable again."
          ]
        },
        "timeRange": {
          "$ref": "GoogleTypeInterval"
        }
      },
      "id": "GoogleCloudContentwarehouseV1TimeFilter",
      "description": "Filter on create timestamp or update timestamp of documents."
    },
    "GoogleTypeInterval": {
      "id": "GoogleTypeInterval",
      "description": "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.",
      "properties": {
        "endTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "Optional. Exclusive end of the interval. If specified, a Timestamp matching this interval will have to be before the end."
        },
        "startTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "Optional. Inclusive start of the interval. If specified, a Timestamp matching this interval will have to be the same or after the start."
        }
      },
      "type": "object"
    }
  },
  "resources": {
    "projects": {
      "methods": {
        "setAcl": {
          "flatPath": "v1/projects/{projectsId}:setAcl",
          "id": "contentwarehouse.projects.setAcl",
          "description": "Sets the access control policy for a resource. Replaces any existing policy.",
          "path": "v1/{+resource}:setAcl",
          "parameterOrder": [
            "resource"
          ],
          "request": {
            "$ref": "GoogleCloudContentwarehouseV1SetAclRequest"
          },
          "httpMethod": "POST",
          "parameters": {
            "resource": {
              "pattern": "^projects/[^/]+$",
              "description": "Required. REQUIRED: The resource for which the policy is being requested. Format for document: projects/{project_number}/locations/{location}/documents/{document_id}. Format for collection: projects/{project_number}/locations/{location}/collections/{collection_id}. Format for project: projects/{project_number}.",
              "type": "string",
              "required": true,
              "location": "path"
            }
          },
          "response": {
            "$ref": "GoogleCloudContentwarehouseV1SetAclResponse"
          },
          "scopes": [
            "https://www.googleapis.com/auth/cloud-platform"
          ]
        },
        "fetchAcl": {
          "httpMethod": "POST",
          "response": {
            "$ref": "GoogleCloudContentwarehouseV1FetchAclResponse"
          },
          "flatPath": "v1/projects/{projectsId}:fetchAcl",
          "path": "v1/{+resource}:fetchAcl",
          "scopes": [
            "https://www.googleapis.com/auth/cloud-platform"
          ],
          "parameters": {
            "resource": {
              "pattern": "^projects/[^/]+$",
              "description": "Required. REQUIRED: The resource for which the policy is being requested. Format for document: projects/{project_number}/locations/{location}/documents/{document_id}. Format for collection: projects/{project_number}/locations/{location}/collections/{collection_id}. Format for project: projects/{project_number}.",
              "type": "string",
              "location": "path",
              "required": true
            }
          },
          "description": "Gets the access control policy for a resource. Returns NOT_FOUND error if the resource does not exist. Returns an empty policy if the resource exists but does not have a policy set.",
          "request": {
            "$ref": "GoogleCloudContentwarehouseV1FetchAclRequest"
          },
          "id": "contentwarehouse.projects.fetchAcl",
          "parameterOrder": [
            "resource"
          ]
        }
      },
      "resources": {
        "locations": {
          "methods": {
            "runPipeline": {
              "response": {
                "$ref": "GoogleLongrunningOperation"
              },
              "description": "Run a predefined pipeline.",
              "request": {
                "$ref": "GoogleCloudContentwarehouseV1RunPipelineRequest"
              },
              "id": "contentwarehouse.projects.locations.runPipeline",
              "path": "v1/{+name}:runPipeline",
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "flatPath": "v1/projects/{projectsId}/locations/{locationsId}:runPipeline",
              "parameters": {
                "name": {
                  "description": "Required. The resource name which owns the resources of the pipeline. Format: projects/{project_number}/locations/{location}.",
                  "required": true,
                  "location": "path",
                  "type": "string",
                  "pattern": "^projects/[^/]+/locations/[^/]+$"
                }
              },
              "parameterOrder": [
                "name"
              ],
              "httpMethod": "POST"
            },
            "getStatus": {
              "description": "Get the project status.",
              "id": "contentwarehouse.projects.locations.getStatus",
              "parameters": {
                "location": {
                  "location": "path",
                  "pattern": "^projects/[^/]+/locations/[^/]+$",
                  "type": "string",
                  "description": "Required. The location to be queried Format: projects/{project_number}/locations/{location}.",
                  "required": true
                }
              },
              "flatPath": "v1/projects/{projectsId}/locations/{locationsId}:getStatus",
              "path": "v1/{+location}:getStatus",
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "response": {
                "$ref": "GoogleCloudContentwarehouseV1ProjectStatus"
              },
              "httpMethod": "GET",
              "parameterOrder": [
                "location"
              ]
            },
            "initialize": {
              "flatPath": "v1/projects/{projectsId}/locations/{locationsId}:initialize",
              "parameters": {
                "location": {
                  "location": "path",
                  "type": "string",
                  "pattern": "^projects/[^/]+/locations/[^/]+$",
                  "required": true,
                  "description": "Required. The location to be initialized Format: projects/{project_number}/locations/{location}."
                }
              },
              "httpMethod": "POST",
              "response": {
                "$ref": "GoogleLongrunningOperation"
              },
              "path": "v1/{+location}:initialize",
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "id": "contentwarehouse.projects.locations.initialize",
              "request": {
                "$ref": "GoogleCloudContentwarehouseV1InitializeProjectRequest"
              },
              "description": "Provisions resources for given tenant project. Returns a long running operation.",
              "parameterOrder": [
                "location"
              ]
            }
          },
          "resources": {
            "ruleSets": {
              "methods": {
                "delete": {
                  "id": "contentwarehouse.projects.locations.ruleSets.delete",
                  "description": "Deletes a ruleset. Returns NOT_FOUND if the document does not exist.",
                  "httpMethod": "DELETE",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/ruleSets/{ruleSetsId}",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameters": {
                    "name": {
                      "location": "path",
                      "pattern": "^projects/[^/]+/locations/[^/]+/ruleSets/[^/]+$",
                      "type": "string",
                      "description": "Required. The name of the rule set to delete. Format: projects/{project_number}/locations/{location}/ruleSets/{rule_set_id}.",
                      "required": true
                    }
                  },
                  "response": {
                    "$ref": "GoogleProtobufEmpty"
                  },
                  "path": "v1/{+name}",
                  "parameterOrder": [
                    "name"
                  ]
                },
                "get": {
                  "id": "contentwarehouse.projects.locations.ruleSets.get",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/ruleSets/{ruleSetsId}",
                  "parameterOrder": [
                    "name"
                  ],
                  "httpMethod": "GET",
                  "parameters": {
                    "name": {
                      "pattern": "^projects/[^/]+/locations/[^/]+/ruleSets/[^/]+$",
                      "type": "string",
                      "description": "Required. The name of the rule set to retrieve. Format: projects/{project_number}/locations/{location}/ruleSets/{rule_set_id}.",
                      "required": true,
                      "location": "path"
                    }
                  },
                  "path": "v1/{+name}",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1RuleSet"
                  },
                  "description": "Gets a ruleset. Returns NOT_FOUND if the ruleset does not exist."
                },
                "list": {
                  "path": "v1/{+parent}/ruleSets",
                  "parameters": {
                    "pageToken": {
                      "description": "A page token, received from a previous `ListRuleSets` call. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to `ListRuleSets` must match the call that provided the page token.",
                      "type": "string",
                      "location": "query"
                    },
                    "parent": {
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "required": true,
                      "description": "Required. The parent, which owns this collection of document. Format: projects/{project_number}/locations/{location}.",
                      "location": "path",
                      "type": "string"
                    },
                    "pageSize": {
                      "description": "The maximum number of rule sets to return. The service may return fewer than this value. If unspecified, at most 50 rule sets will be returned. The maximum value is 1000; values above 1000 will be coerced to 1000.",
                      "format": "int32",
                      "type": "integer",
                      "location": "query"
                    }
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/ruleSets",
                  "id": "contentwarehouse.projects.locations.ruleSets.list",
                  "httpMethod": "GET",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameterOrder": [
                    "parent"
                  ],
                  "description": "Lists rulesets.",
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1ListRuleSetsResponse"
                  }
                },
                "patch": {
                  "id": "contentwarehouse.projects.locations.ruleSets.patch",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameters": {
                    "name": {
                      "description": "Required. The name of the rule set to update. Format: projects/{project_number}/locations/{location}/ruleSets/{rule_set_id}.",
                      "location": "path",
                      "required": true,
                      "pattern": "^projects/[^/]+/locations/[^/]+/ruleSets/[^/]+$",
                      "type": "string"
                    }
                  },
                  "httpMethod": "PATCH",
                  "parameterOrder": [
                    "name"
                  ],
                  "path": "v1/{+name}",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/ruleSets/{ruleSetsId}",
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1RuleSet"
                  },
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1UpdateRuleSetRequest"
                  },
                  "description": "Updates a ruleset. Returns INVALID_ARGUMENT if the name of the ruleset is non-empty and does not equal the existing name."
                },
                "create": {
                  "parameterOrder": [
                    "parent"
                  ],
                  "httpMethod": "POST",
                  "parameters": {
                    "parent": {
                      "location": "path",
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "description": "Required. The parent name. Format: projects/{project_number}/locations/{location}.",
                      "type": "string",
                      "required": true
                    }
                  },
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1RuleSet"
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "description": "Creates a ruleset.",
                  "path": "v1/{+parent}/ruleSets",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/ruleSets",
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1RuleSet"
                  },
                  "id": "contentwarehouse.projects.locations.ruleSets.create"
                }
              }
            },
            "documentSchemas": {
              "methods": {
                "delete": {
                  "parameters": {
                    "name": {
                      "location": "path",
                      "type": "string",
                      "pattern": "^projects/[^/]+/locations/[^/]+/documentSchemas/[^/]+$",
                      "required": true,
                      "description": "Required. The name of the document schema to delete."
                    }
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "httpMethod": "DELETE",
                  "response": {
                    "$ref": "GoogleProtobufEmpty"
                  },
                  "description": "Deletes a document schema. Returns NOT_FOUND if the document schema does not exist. Returns BAD_REQUEST if the document schema has documents depending on it.",
                  "parameterOrder": [
                    "name"
                  ],
                  "path": "v1/{+name}",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documentSchemas/{documentSchemasId}",
                  "id": "contentwarehouse.projects.locations.documentSchemas.delete"
                },
                "list": {
                  "parameterOrder": [
                    "parent"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "httpMethod": "GET",
                  "parameters": {
                    "parent": {
                      "description": "Required. The parent, which owns this collection of document schemas. Format: projects/{project_number}/locations/{location}.",
                      "required": true,
                      "location": "path",
                      "type": "string",
                      "pattern": "^projects/[^/]+/locations/[^/]+$"
                    },
                    "pageSize": {
                      "type": "integer",
                      "format": "int32",
                      "description": "The maximum number of document schemas to return. The service may return fewer than this value. If unspecified, at most 50 document schemas will be returned. The maximum value is 1000; values above 1000 will be coerced to 1000.",
                      "location": "query"
                    },
                    "pageToken": {
                      "type": "string",
                      "description": "A page token, received from a previous `ListDocumentSchemas` call. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to `ListDocumentSchemas` must match the call that provided the page token.",
                      "location": "query"
                    }
                  },
                  "description": "Lists document schemas.",
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1ListDocumentSchemasResponse"
                  },
                  "path": "v1/{+parent}/documentSchemas",
                  "id": "contentwarehouse.projects.locations.documentSchemas.list",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documentSchemas"
                },
                "create": {
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documentSchemas",
                  "httpMethod": "POST",
                  "parameters": {
                    "parent": {
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "location": "path",
                      "required": true,
                      "description": "Required. The parent name.",
                      "type": "string"
                    }
                  },
                  "parameterOrder": [
                    "parent"
                  ],
                  "path": "v1/{+parent}/documentSchemas",
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1DocumentSchema"
                  },
                  "id": "contentwarehouse.projects.locations.documentSchemas.create",
                  "description": "Creates a document schema.",
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1DocumentSchema"
                  }
                },
                "patch": {
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1DocumentSchema"
                  },
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1UpdateDocumentSchemaRequest"
                  },
                  "description": "Updates a Document Schema. Returns INVALID_ARGUMENT if the name of the Document Schema is non-empty and does not equal the existing name. Supports only appending new properties, adding new ENUM possible values, and updating the EnumTypeOptions.validation_check_disabled flag for ENUM possible values. Updating existing properties will result into INVALID_ARGUMENT.",
                  "path": "v1/{+name}",
                  "id": "contentwarehouse.projects.locations.documentSchemas.patch",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documentSchemas/{documentSchemasId}",
                  "httpMethod": "PATCH",
                  "parameters": {
                    "name": {
                      "type": "string",
                      "pattern": "^projects/[^/]+/locations/[^/]+/documentSchemas/[^/]+$",
                      "required": true,
                      "location": "path",
                      "description": "Required. The name of the document schema to update. Format: projects/{project_number}/locations/{location}/documentSchemas/{document_schema_id}."
                    }
                  },
                  "parameterOrder": [
                    "name"
                  ]
                },
                "get": {
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameterOrder": [
                    "name"
                  ],
                  "httpMethod": "GET",
                  "path": "v1/{+name}",
                  "parameters": {
                    "name": {
                      "required": true,
                      "location": "path",
                      "pattern": "^projects/[^/]+/locations/[^/]+/documentSchemas/[^/]+$",
                      "description": "Required. The name of the document schema to retrieve.",
                      "type": "string"
                    }
                  },
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1DocumentSchema"
                  },
                  "id": "contentwarehouse.projects.locations.documentSchemas.get",
                  "description": "Gets a document schema. Returns NOT_FOUND if the document schema does not exist.",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documentSchemas/{documentSchemasId}"
                }
              }
            },
            "synonymSets": {
              "methods": {
                "get": {
                  "parameters": {
                    "name": {
                      "location": "path",
                      "required": true,
                      "description": "Required. The name of the synonymSet to retrieve Format: projects/{project_number}/locations/{location}/synonymSets/{context}.",
                      "pattern": "^projects/[^/]+/locations/[^/]+/synonymSets/[^/]+$",
                      "type": "string"
                    }
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "path": "v1/{+name}",
                  "id": "contentwarehouse.projects.locations.synonymSets.get",
                  "description": "Gets a SynonymSet for a particular context. Throws a NOT_FOUND exception if the Synonymset does not exist",
                  "parameterOrder": [
                    "name"
                  ],
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1SynonymSet"
                  },
                  "httpMethod": "GET",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/synonymSets/{synonymSetsId}"
                },
                "list": {
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/synonymSets",
                  "parameterOrder": [
                    "parent"
                  ],
                  "id": "contentwarehouse.projects.locations.synonymSets.list",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "path": "v1/{+parent}/synonymSets",
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1ListSynonymSetsResponse"
                  },
                  "description": "Returns all SynonymSets (for all contexts) for the specified location.",
                  "parameters": {
                    "pageToken": {
                      "description": "A page token, received from a previous `ListSynonymSets` call. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to `ListSynonymSets` must match the call that provided the page token.",
                      "type": "string",
                      "location": "query"
                    },
                    "parent": {
                      "description": "Required. The parent name. Format: projects/{project_number}/locations/{location}.",
                      "required": true,
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "location": "path",
                      "type": "string"
                    },
                    "pageSize": {
                      "location": "query",
                      "type": "integer",
                      "description": "The maximum number of synonymSets to return. The service may return fewer than this value. If unspecified, at most 50 rule sets will be returned. The maximum value is 1000; values above 1000 will be coerced to 1000.",
                      "format": "int32"
                    }
                  }
                },
                "create": {
                  "path": "v1/{+parent}/synonymSets",
                  "parameters": {
                    "parent": {
                      "required": true,
                      "location": "path",
                      "type": "string",
                      "description": "Required. The parent name. Format: projects/{project_number}/locations/{location}.",
                      "pattern": "^projects/[^/]+/locations/[^/]+$"
                    }
                  },
                  "id": "contentwarehouse.projects.locations.synonymSets.create",
                  "description": "Creates a SynonymSet for a single context. Throws an ALREADY_EXISTS exception if a synonymset already exists for the context.",
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1SynonymSet"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/synonymSets",
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1SynonymSet"
                  },
                  "httpMethod": "POST",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameterOrder": [
                    "parent"
                  ]
                },
                "patch": {
                  "id": "contentwarehouse.projects.locations.synonymSets.patch",
                  "parameters": {
                    "name": {
                      "required": true,
                      "location": "path",
                      "type": "string",
                      "pattern": "^projects/[^/]+/locations/[^/]+/synonymSets/[^/]+$",
                      "description": "Required. The name of the synonymSet to update Format: projects/{project_number}/locations/{location}/synonymSets/{context}."
                    }
                  },
                  "path": "v1/{+name}",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/synonymSets/{synonymSetsId}",
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1SynonymSet"
                  },
                  "parameterOrder": [
                    "name"
                  ],
                  "httpMethod": "PATCH",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "description": "Remove the existing SynonymSet for the context and replaces it with a new one. Throws a NOT_FOUND exception if the SynonymSet is not found.",
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1SynonymSet"
                  }
                },
                "delete": {
                  "parameters": {
                    "name": {
                      "pattern": "^projects/[^/]+/locations/[^/]+/synonymSets/[^/]+$",
                      "location": "path",
                      "required": true,
                      "description": "Required. The name of the synonymSet to delete Format: projects/{project_number}/locations/{location}/synonymSets/{context}.",
                      "type": "string"
                    }
                  },
                  "path": "v1/{+name}",
                  "httpMethod": "DELETE",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/synonymSets/{synonymSetsId}",
                  "response": {
                    "$ref": "GoogleProtobufEmpty"
                  },
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Deletes a SynonymSet for a given context. Throws a NOT_FOUND exception if the SynonymSet is not found.",
                  "id": "contentwarehouse.projects.locations.synonymSets.delete",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                }
              }
            },
            "documents": {
              "methods": {
                "linkedTargets": {
                  "httpMethod": "POST",
                  "parameters": {
                    "parent": {
                      "required": true,
                      "description": "Required. The name of the document, for which all target links are returned. Format: projects/{project_number}/locations/{location}/documents/{target_document_id}.",
                      "type": "string",
                      "pattern": "^projects/[^/]+/locations/[^/]+/documents/[^/]+$",
                      "location": "path"
                    }
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1ListLinkedTargetsResponse"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/{documentsId}/linkedTargets",
                  "description": "Return all target document-links from the document.",
                  "path": "v1/{+parent}/linkedTargets",
                  "parameterOrder": [
                    "parent"
                  ],
                  "id": "contentwarehouse.projects.locations.documents.linkedTargets",
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1ListLinkedTargetsRequest"
                  }
                },
                "patch": {
                  "parameterOrder": [
                    "name"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/{documentsId}",
                  "path": "v1/{+name}",
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1UpdateDocumentRequest"
                  },
                  "id": "contentwarehouse.projects.locations.documents.patch",
                  "httpMethod": "PATCH",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "description": "Updates a document. Returns INVALID_ARGUMENT if the name of the document is non-empty and does not equal the existing name.",
                  "parameters": {
                    "name": {
                      "pattern": "^projects/[^/]+/locations/[^/]+/documents/[^/]+$",
                      "description": "Required. The name of the document to update. Format: projects/{project_number}/locations/{location}/documents/{document_id} or projects/{project_number}/locations/{location}/documents/referenceId/{reference_id}.",
                      "location": "path",
                      "required": true,
                      "type": "string"
                    }
                  },
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1UpdateDocumentResponse"
                  }
                },
                "lock": {
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameterOrder": [
                    "name"
                  ],
                  "id": "contentwarehouse.projects.locations.documents.lock",
                  "parameters": {
                    "name": {
                      "location": "path",
                      "required": true,
                      "description": "Required. The name of the document to lock. Format: projects/{project_number}/locations/{location}/documents/{document}.",
                      "type": "string",
                      "pattern": "^projects/[^/]+/locations/[^/]+/documents/[^/]+$"
                    }
                  },
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1Document"
                  },
                  "path": "v1/{+name}:lock",
                  "description": "Lock the document so the document cannot be updated by other users.",
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1LockDocumentRequest"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/{documentsId}:lock",
                  "httpMethod": "POST"
                },
                "create": {
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "id": "contentwarehouse.projects.locations.documents.create",
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1CreateDocumentRequest"
                  },
                  "parameterOrder": [
                    "parent"
                  ],
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1CreateDocumentResponse"
                  },
                  "path": "v1/{+parent}/documents",
                  "httpMethod": "POST",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents",
                  "parameters": {
                    "parent": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "description": "Required. The parent name. Format: projects/{project_number}/locations/{location}."
                    }
                  },
                  "description": "Creates a document."
                },
                "linkedSources": {
                  "httpMethod": "POST",
                  "path": "v1/{+parent}/linkedSources",
                  "description": "Return all source document-links from the document.",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/{documentsId}/linkedSources",
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1ListLinkedSourcesResponse"
                  },
                  "parameters": {
                    "parent": {
                      "type": "string",
                      "description": "Required. The name of the document, for which all source links are returned. Format: projects/{project_number}/locations/{location}/documents/{source_document_id}.",
                      "required": true,
                      "pattern": "^projects/[^/]+/locations/[^/]+/documents/[^/]+$",
                      "location": "path"
                    }
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameterOrder": [
                    "parent"
                  ],
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1ListLinkedSourcesRequest"
                  },
                  "id": "contentwarehouse.projects.locations.documents.linkedSources"
                },
                "delete": {
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/{documentsId}:delete",
                  "parameterOrder": [
                    "name"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "response": {
                    "$ref": "GoogleProtobufEmpty"
                  },
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1DeleteDocumentRequest"
                  },
                  "id": "contentwarehouse.projects.locations.documents.delete",
                  "httpMethod": "POST",
                  "path": "v1/{+name}:delete",
                  "parameters": {
                    "name": {
                      "description": "Required. The name of the document to delete. Format: projects/{project_number}/locations/{location}/documents/{document_id} or projects/{project_number}/locations/{location}/documents/referenceId/{reference_id}.",
                      "required": true,
                      "type": "string",
                      "location": "path",
                      "pattern": "^projects/[^/]+/locations/[^/]+/documents/[^/]+$"
                    }
                  },
                  "description": "Deletes a document. Returns NOT_FOUND if the document does not exist."
                },
                "get": {
                  "id": "contentwarehouse.projects.locations.documents.get",
                  "parameters": {
                    "name": {
                      "required": true,
                      "type": "string",
                      "pattern": "^projects/[^/]+/locations/[^/]+/documents/[^/]+$",
                      "location": "path",
                      "description": "Required. The name of the document to retrieve. Format: projects/{project_number}/locations/{location}/documents/{document_id} or projects/{project_number}/locations/{location}/documents/referenceId/{reference_id}."
                    }
                  },
                  "path": "v1/{+name}:get",
                  "httpMethod": "POST",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/{documentsId}:get",
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1Document"
                  },
                  "parameterOrder": [
                    "name"
                  ],
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1GetDocumentRequest"
                  },
                  "description": "Gets a document. Returns NOT_FOUND if the document does not exist.",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                },
                "search": {
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1SearchDocumentsResponse"
                  },
                  "description": "Searches for documents using provided SearchDocumentsRequest. This call only returns documents that the caller has permission to search against.",
                  "httpMethod": "POST",
                  "parameterOrder": [
                    "parent"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameters": {
                    "parent": {
                      "description": "Required. The parent, which owns this collection of documents. Format: projects/{project_number}/locations/{location}.",
                      "location": "path",
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "type": "string",
                      "required": true
                    }
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents:search",
                  "id": "contentwarehouse.projects.locations.documents.search",
                  "path": "v1/{+parent}/documents:search",
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1SearchDocumentsRequest"
                  }
                },
                "setAcl": {
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/{documentsId}:setAcl",
                  "description": "Sets the access control policy for a resource. Replaces any existing policy.",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "id": "contentwarehouse.projects.locations.documents.setAcl",
                  "parameterOrder": [
                    "resource"
                  ],
                  "path": "v1/{+resource}:setAcl",
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1SetAclRequest"
                  },
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1SetAclResponse"
                  },
                  "parameters": {
                    "resource": {
                      "type": "string",
                      "location": "path",
                      "pattern": "^projects/[^/]+/locations/[^/]+/documents/[^/]+$",
                      "description": "Required. REQUIRED: The resource for which the policy is being requested. Format for document: projects/{project_number}/locations/{location}/documents/{document_id}. Format for collection: projects/{project_number}/locations/{location}/collections/{collection_id}. Format for project: projects/{project_number}.",
                      "required": true
                    }
                  },
                  "httpMethod": "POST"
                },
                "fetchAcl": {
                  "httpMethod": "POST",
                  "path": "v1/{+resource}:fetchAcl",
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1FetchAclResponse"
                  },
                  "parameterOrder": [
                    "resource"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "description": "Gets the access control policy for a resource. Returns NOT_FOUND error if the resource does not exist. Returns an empty policy if the resource exists but does not have a policy set.",
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1FetchAclRequest"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/{documentsId}:fetchAcl",
                  "parameters": {
                    "resource": {
                      "location": "path",
                      "description": "Required. REQUIRED: The resource for which the policy is being requested. Format for document: projects/{project_number}/locations/{location}/documents/{document_id}. Format for collection: projects/{project_number}/locations/{location}/collections/{collection_id}. Format for project: projects/{project_number}.",
                      "required": true,
                      "type": "string",
                      "pattern": "^projects/[^/]+/locations/[^/]+/documents/[^/]+$"
                    }
                  },
                  "id": "contentwarehouse.projects.locations.documents.fetchAcl"
                }
              },
              "resources": {
                "documentLinks": {
                  "methods": {
                    "create": {
                      "request": {
                        "$ref": "GoogleCloudContentwarehouseV1CreateDocumentLinkRequest"
                      },
                      "description": "Create a link between a source document and a target document.",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "parameterOrder": [
                        "parent"
                      ],
                      "id": "contentwarehouse.projects.locations.documents.documentLinks.create",
                      "parameters": {
                        "parent": {
                          "required": true,
                          "location": "path",
                          "pattern": "^projects/[^/]+/locations/[^/]+/documents/[^/]+$",
                          "description": "Required. Parent of the document-link to be created. parent of document-link should be a document. Format: projects/{project_number}/locations/{location}/documents/{source_document_id}.",
                          "type": "string"
                        }
                      },
                      "response": {
                        "$ref": "GoogleCloudContentwarehouseV1DocumentLink"
                      },
                      "httpMethod": "POST",
                      "path": "v1/{+parent}/documentLinks",
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/{documentsId}/documentLinks"
                    },
                    "delete": {
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/{documentsId}/documentLinks/{documentLinksId}:delete",
                      "parameterOrder": [
                        "name"
                      ],
                      "request": {
                        "$ref": "GoogleCloudContentwarehouseV1DeleteDocumentLinkRequest"
                      },
                      "path": "v1/{+name}:delete",
                      "httpMethod": "POST",
                      "parameters": {
                        "name": {
                          "required": true,
                          "location": "path",
                          "type": "string",
                          "pattern": "^projects/[^/]+/locations/[^/]+/documents/[^/]+/documentLinks/[^/]+$",
                          "description": "Required. The name of the document-link to be deleted. Format: projects/{project_number}/locations/{location}/documents/{source_document_id}/documentLinks/{document_link_id}."
                        }
                      },
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "description": "Remove the link between the source and target documents.",
                      "id": "contentwarehouse.projects.locations.documents.documentLinks.delete",
                      "response": {
                        "$ref": "GoogleProtobufEmpty"
                      }
                    }
                  }
                },
                "referenceId": {
                  "methods": {
                    "patch": {
                      "httpMethod": "PATCH",
                      "request": {
                        "$ref": "GoogleCloudContentwarehouseV1UpdateDocumentRequest"
                      },
                      "description": "Updates a document. Returns INVALID_ARGUMENT if the name of the document is non-empty and does not equal the existing name.",
                      "path": "v1/{+name}",
                      "parameters": {
                        "name": {
                          "type": "string",
                          "pattern": "^projects/[^/]+/locations/[^/]+/documents/referenceId/[^/]+$",
                          "location": "path",
                          "required": true,
                          "description": "Required. The name of the document to update. Format: projects/{project_number}/locations/{location}/documents/{document_id} or projects/{project_number}/locations/{location}/documents/referenceId/{reference_id}."
                        }
                      },
                      "parameterOrder": [
                        "name"
                      ],
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/referenceId/{referenceIdId}",
                      "id": "contentwarehouse.projects.locations.documents.referenceId.patch",
                      "response": {
                        "$ref": "GoogleCloudContentwarehouseV1UpdateDocumentResponse"
                      },
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ]
                    },
                    "get": {
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/referenceId/{referenceIdId}:get",
                      "response": {
                        "$ref": "GoogleCloudContentwarehouseV1Document"
                      },
                      "description": "Gets a document. Returns NOT_FOUND if the document does not exist.",
                      "path": "v1/{+name}:get",
                      "parameterOrder": [
                        "name"
                      ],
                      "parameters": {
                        "name": {
                          "description": "Required. The name of the document to retrieve. Format: projects/{project_number}/locations/{location}/documents/{document_id} or projects/{project_number}/locations/{location}/documents/referenceId/{reference_id}.",
                          "pattern": "^projects/[^/]+/locations/[^/]+/documents/referenceId/[^/]+$",
                          "type": "string",
                          "location": "path",
                          "required": true
                        }
                      },
                      "request": {
                        "$ref": "GoogleCloudContentwarehouseV1GetDocumentRequest"
                      },
                      "id": "contentwarehouse.projects.locations.documents.referenceId.get",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "httpMethod": "POST"
                    },
                    "delete": {
                      "httpMethod": "POST",
                      "response": {
                        "$ref": "GoogleProtobufEmpty"
                      },
                      "path": "v1/{+name}:delete",
                      "parameters": {
                        "name": {
                          "type": "string",
                          "pattern": "^projects/[^/]+/locations/[^/]+/documents/referenceId/[^/]+$",
                          "description": "Required. The name of the document to delete. Format: projects/{project_number}/locations/{location}/documents/{document_id} or projects/{project_number}/locations/{location}/documents/referenceId/{reference_id}.",
                          "required": true,
                          "location": "path"
                        }
                      },
                      "parameterOrder": [
                        "name"
                      ],
                      "request": {
                        "$ref": "GoogleCloudContentwarehouseV1DeleteDocumentRequest"
                      },
                      "description": "Deletes a document. Returns NOT_FOUND if the document does not exist.",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/referenceId/{referenceIdId}:delete",
                      "id": "contentwarehouse.projects.locations.documents.referenceId.delete"
                    }
                  }
                }
              }
            },
            "operations": {
              "methods": {
                "get": {
                  "parameters": {
                    "name": {
                      "type": "string",
                      "description": "The name of the operation resource.",
                      "pattern": "^projects/[^/]+/locations/[^/]+/operations/[^/]+$",
                      "required": true,
                      "location": "path"
                    }
                  },
                  "httpMethod": "GET",
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "path": "v1/{+name}",
                  "id": "contentwarehouse.projects.locations.operations.get",
                  "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/operations/{operationsId}",
                  "parameterOrder": [
                    "name"
                  ]
                }
              }
            }
          }
        }
      }
    }
  },
  "protocol": "rest",
  "version": "v1",
  "name": "contentwarehouse",
  "auth": {
    "oauth2": {
      "scopes": {
        "https://www.googleapis.com/auth/cloud-platform": {
          "description": "See, edit, configure, and delete your Google Cloud data and see the email address for your Google Account."
        }
      }
    }
  },
  "discoveryVersion": "v1",
  "id": "contentwarehouse:v1",
  "canonicalName": "contentwarehouse",
  "basePath": "",
  "ownerName": "Google",
  "title": "Document AI Warehouse API",
  "kind": "discovery#restDescription"
}
