{
  "version_module": true,
  "fullyEncodeReservedExpansion": true,
  "id": "contentwarehouse:v1",
  "revision": "20250206",
  "icons": {
    "x16": "http://www.google.com/images/icons/product/search-16.gif",
    "x32": "http://www.google.com/images/icons/product/search-32.gif"
  },
  "mtlsRootUrl": "https://contentwarehouse.mtls.googleapis.com/",
  "schemas": {
    "GoogleCloudContentwarehouseV1MapTypeOptions": {
      "description": "Configurations for a Map property.",
      "type": "object",
      "properties": {},
      "id": "GoogleCloudContentwarehouseV1MapTypeOptions"
    },
    "GoogleCloudContentwarehouseV1TimestampArray": {
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1TimestampArray",
      "properties": {
        "values": {
          "description": "List of timestamp values.",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1TimestampValue"
          },
          "type": "array"
        }
      },
      "description": "Timestamp values."
    },
    "GoogleCloudContentwarehouseV1LockDocumentRequest": {
      "properties": {
        "collectionId": {
          "description": "The collection the document connects to.",
          "type": "string"
        },
        "lockingUser": {
          "description": "The user information who locks the document.",
          "$ref": "GoogleCloudContentwarehouseV1UserInfo"
        }
      },
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1LockDocumentRequest",
      "description": "Request message for DocumentService.LockDocument."
    },
    "GoogleCloudContentwarehouseV1SearchDocumentsResponse": {
      "description": "Response message for DocumentService.SearchDocuments.",
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1SearchDocumentsResponse",
      "properties": {
        "matchingDocuments": {
          "description": "The document entities that match the specified SearchDocumentsRequest.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1SearchDocumentsResponseMatchingDocument"
          }
        },
        "histogramQueryResults": {
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1HistogramQueryResult"
          },
          "type": "array",
          "description": "The histogram results that match with the specified SearchDocumentsRequest.histogram_queries."
        },
        "metadata": {
          "description": "Additional information for the API invocation, such as the request tracking id.",
          "$ref": "GoogleCloudContentwarehouseV1ResponseMetadata"
        },
        "totalSize": {
          "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\".",
          "format": "int32",
          "type": "integer"
        },
        "questionAnswer": {
          "description": "Experimental. Question answer from the query against the document.",
          "type": "string"
        },
        "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"
        }
      }
    },
    "GoogleCloudDocumentaiV1DocumentPageDimension": {
      "type": "object",
      "properties": {
        "unit": {
          "type": "string",
          "description": "Dimension unit."
        },
        "height": {
          "description": "Page height.",
          "type": "number",
          "format": "float"
        },
        "width": {
          "type": "number",
          "description": "Page width.",
          "format": "float"
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentPageDimension",
      "description": "Dimension for the page."
    },
    "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlock": {
      "description": "Represents a block. A block could be one of the various types (text, table, list) supported.",
      "id": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlock",
      "properties": {
        "tableBlock": {
          "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTableBlock",
          "description": "Block consisting of table content/structure."
        },
        "listBlock": {
          "description": "Block consisting of list content/structure.",
          "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutListBlock"
        },
        "pageSpan": {
          "description": "Page span of the block.",
          "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutPageSpan"
        },
        "textBlock": {
          "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTextBlock",
          "description": "Block consisting of text content."
        },
        "blockId": {
          "type": "string",
          "description": "ID of the block."
        }
      },
      "type": "object"
    },
    "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTableRow": {
      "type": "object",
      "properties": {
        "cells": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTableCell"
          },
          "description": "A table row is a list of table cells.",
          "type": "array"
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTableRow",
      "description": "Represents a row in a table."
    },
    "GoogleCloudContentwarehouseV1TextTypeOptions": {
      "id": "GoogleCloudContentwarehouseV1TextTypeOptions",
      "type": "object",
      "description": "Configurations for a text property.",
      "properties": {}
    },
    "GoogleCloudContentwarehouseV1DocumentReference": {
      "description": "References to the documents.",
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1DocumentReference",
      "properties": {
        "documentIsLegalHoldFolder": {
          "description": "Document is a folder with legal hold.",
          "type": "boolean"
        },
        "snippet": {
          "description": "Stores the subset of the referenced document's content. This is useful to allow user peek the information of the referenced document.",
          "type": "string"
        },
        "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"
        },
        "updateTime": {
          "format": "google-datetime",
          "type": "string",
          "description": "Output only. The time when the document is last updated.",
          "readOnly": true
        },
        "createTime": {
          "description": "Output only. The time when the document is created.",
          "readOnly": true,
          "format": "google-datetime",
          "type": "string"
        },
        "documentIsRetentionFolder": {
          "type": "boolean",
          "description": "Document is a folder with retention policy."
        },
        "deleteTime": {
          "type": "string",
          "format": "google-datetime",
          "readOnly": true,
          "description": "Output only. The time when the document is deleted."
        },
        "documentName": {
          "type": "string",
          "description": "Required. Name of the referenced document."
        },
        "documentIsFolder": {
          "type": "boolean",
          "description": "The document type of the document being referenced."
        }
      }
    },
    "GoogleCloudDocumentaiV1DocumentTextChange": {
      "properties": {
        "textAnchor": {
          "$ref": "GoogleCloudDocumentaiV1DocumentTextAnchor",
          "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."
        },
        "provenance": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentProvenance"
          },
          "description": "The history of this annotation.",
          "deprecated": true,
          "type": "array"
        },
        "changedText": {
          "description": "The text that replaces the text identified in the `text_anchor`.",
          "type": "string"
        }
      },
      "type": "object",
      "description": "This message is used for text changes aka. OCR corrections.",
      "id": "GoogleCloudDocumentaiV1DocumentTextChange"
    },
    "GoogleCloudContentwarehouseV1Document": {
      "description": "Defines the structure for content warehouse document proto.",
      "properties": {
        "createTime": {
          "format": "google-datetime",
          "description": "Output only. The time when the document is created.",
          "type": "string",
          "readOnly": true
        },
        "updateTime": {
          "format": "google-datetime",
          "type": "string",
          "readOnly": true,
          "description": "Output only. The time when the document is last updated."
        },
        "cloudAiDocument": {
          "description": "Document AI format to save the structured content, including OCR.",
          "$ref": "GoogleCloudDocumentaiV1Document"
        },
        "textExtractionEnabled": {
          "type": "boolean",
          "description": "If true, text extraction will be performed."
        },
        "plainText": {
          "type": "string",
          "description": "Other document format, such as PPTX, XLXS"
        },
        "creator": {
          "type": "string",
          "description": "The user who creates the document."
        },
        "textExtractionDisabled": {
          "type": "boolean",
          "description": "If true, text extraction will not be performed.",
          "deprecated": true
        },
        "inlineRawDocument": {
          "type": "string",
          "description": "Raw document content.",
          "format": "byte"
        },
        "referenceId": {
          "type": "string",
          "description": "The reference ID set by customers. Must be unique per project and location."
        },
        "contentCategory": {
          "description": "Indicates the category (image, audio, video etc.) of the original content.",
          "enumDescriptions": [
            "No category is specified.",
            "Content is of image type.",
            "Content is of audio type.",
            "Content is of video type."
          ],
          "type": "string",
          "enum": [
            "CONTENT_CATEGORY_UNSPECIFIED",
            "CONTENT_CATEGORY_IMAGE",
            "CONTENT_CATEGORY_AUDIO",
            "CONTENT_CATEGORY_VIDEO"
          ]
        },
        "name": {
          "type": "string",
          "description": "The resource name of the document. Format: projects/{project_number}/locations/{location}/documents/{document_id}. The name is ignored when creating a document."
        },
        "rawDocumentPath": {
          "description": "Raw document file in Cloud Storage path.",
          "type": "string"
        },
        "dispositionTime": {
          "readOnly": true,
          "format": "google-datetime",
          "type": "string",
          "description": "Output only. If linked to a Collection with RetentionPolicy, the date when the document becomes mutable."
        },
        "properties": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1Property"
          },
          "description": "List of values that are user supplied metadata."
        },
        "displayUri": {
          "type": "string",
          "description": "Uri to display the document, for example, in the UI."
        },
        "legalHold": {
          "description": "Output only. Indicates if the document has a legal hold on it.",
          "readOnly": true,
          "type": "boolean"
        },
        "rawDocumentFileType": {
          "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.",
          "type": "string",
          "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"
          ],
          "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"
          ]
        },
        "title": {
          "description": "Title that describes the document. This can be the top heading or text that describes the document.",
          "type": "string"
        },
        "displayName": {
          "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.",
          "type": "string"
        },
        "documentSchemaName": {
          "description": "The Document schema name. Format: projects/{project_number}/locations/{location}/documentSchemas/{document_schema_id}.",
          "type": "string"
        },
        "updater": {
          "type": "string",
          "description": "The user who lastly updates the document."
        }
      },
      "id": "GoogleCloudContentwarehouseV1Document",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1beta1CreateDocumentMetadata": {
      "properties": {},
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1beta1CreateDocumentMetadata",
      "description": "Metadata object for CreateDocument request (currently empty)."
    },
    "GoogleCloudContentwarehouseV1TimestampTypeOptions": {
      "description": "Configurations for a timestamp property.",
      "properties": {},
      "id": "GoogleCloudContentwarehouseV1TimestampTypeOptions",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1QAResult": {
      "id": "GoogleCloudContentwarehouseV1QAResult",
      "type": "object",
      "description": "Additional result info for the question-answering feature.",
      "properties": {
        "highlights": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1QAResultHighlight"
          },
          "description": "Highlighted sections in the snippet."
        },
        "confidenceScore": {
          "format": "float",
          "type": "number",
          "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."
        }
      }
    },
    "GoogleCloudContentwarehouseV1CreateDocumentResponse": {
      "type": "object",
      "properties": {
        "document": {
          "$ref": "GoogleCloudContentwarehouseV1Document",
          "description": "Document created after executing create request."
        },
        "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": {
          "type": "array",
          "description": "post-processing LROs",
          "items": {
            "$ref": "GoogleLongrunningOperation"
          }
        },
        "metadata": {
          "description": "Additional information for the API invocation, such as the request tracking id.",
          "$ref": "GoogleCloudContentwarehouseV1ResponseMetadata"
        }
      },
      "description": "Response message for DocumentService.CreateDocument.",
      "id": "GoogleCloudContentwarehouseV1CreateDocumentResponse"
    },
    "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunk": {
      "type": "object",
      "description": "Represents a chunk.",
      "properties": {
        "sourceBlockIds": {
          "description": "Unused.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "pageHeaders": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunkChunkPageHeader"
          },
          "type": "array",
          "description": "Page headers associated with the chunk."
        },
        "pageFooters": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunkChunkPageFooter"
          },
          "description": "Page footers associated with the chunk.",
          "type": "array"
        },
        "content": {
          "type": "string",
          "description": "Text content of the chunk."
        },
        "pageSpan": {
          "$ref": "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunkChunkPageSpan",
          "description": "Page span of the chunk."
        },
        "chunkId": {
          "type": "string",
          "description": "ID of the chunk."
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunk"
    },
    "GoogleCloudDocumentaiV1DocumentDocumentLayout": {
      "type": "object",
      "properties": {
        "blocks": {
          "description": "List of blocks in the document.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlock"
          },
          "type": "array"
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentDocumentLayout",
      "description": "Represents the parsed layout of a document as a collection of blocks that the document is divided into."
    },
    "GoogleIamV1Binding": {
      "description": "Associates `members`, or principals, with a `role`.",
      "id": "GoogleIamV1Binding",
      "type": "object",
      "properties": {
        "condition": {
          "$ref": "GoogleTypeExpr",
          "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)."
        },
        "members": {
          "items": {
            "type": "string"
          },
          "type": "array",
          "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`."
        },
        "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"
        }
      }
    },
    "GoogleCloudDocumentaiV1DocumentPageImage": {
      "type": "object",
      "id": "GoogleCloudDocumentaiV1DocumentPageImage",
      "description": "Rendered image contents for this page.",
      "properties": {
        "mimeType": {
          "description": "Encoding [media type (MIME type)](https://www.iana.org/assignments/media-types/media-types.xhtml) for the image.",
          "type": "string"
        },
        "height": {
          "description": "Height of the image in pixels.",
          "format": "int32",
          "type": "integer"
        },
        "content": {
          "description": "Raw byte content of the image.",
          "format": "byte",
          "type": "string"
        },
        "width": {
          "description": "Width of the image in pixels.",
          "format": "int32",
          "type": "integer"
        }
      }
    },
    "GoogleApiServiceconsumermanagementV1PolicyBinding": {
      "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",
      "type": "object",
      "description": "Translates to IAM Policy bindings (without auditing at this level)"
    },
    "GoogleCloudDocumentaiV1DocumentPageTableTableCell": {
      "id": "GoogleCloudDocumentaiV1DocumentPageTableTableCell",
      "properties": {
        "layout": {
          "description": "Layout for TableCell.",
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout"
        },
        "colSpan": {
          "description": "How many columns this cell spans.",
          "type": "integer",
          "format": "int32"
        },
        "detectedLanguages": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage"
          },
          "description": "A list of detected languages together with confidence."
        },
        "rowSpan": {
          "description": "How many rows this cell spans.",
          "type": "integer",
          "format": "int32"
        }
      },
      "type": "object",
      "description": "A cell representation inside the table."
    },
    "GoogleCloudContentwarehouseV1UpdateDocumentSchemaRequest": {
      "id": "GoogleCloudContentwarehouseV1UpdateDocumentSchemaRequest",
      "properties": {
        "documentSchema": {
          "description": "Required. The document schema to update with.",
          "$ref": "GoogleCloudContentwarehouseV1DocumentSchema"
        }
      },
      "description": "Request message for DocumentSchemaService.UpdateDocumentSchema.",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1GcsIngestWithDocAiProcessorsPipeline": {
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1GcsIngestWithDocAiProcessorsPipeline",
      "description": "The configuration of the Cloud Storage Ingestion with DocAI Processors pipeline.",
      "properties": {
        "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"
        },
        "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:///`."
        },
        "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:///`."
        }
      }
    },
    "GoogleCloudContentwarehouseV1DocumentQuery": {
      "type": "object",
      "properties": {
        "isNlQuery": {
          "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.",
          "type": "boolean"
        },
        "documentCreatorFilter": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "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."
        },
        "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"
        },
        "timeFilters": {
          "description": "Documents created/updated within a range specified by this filter are searched against.",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1TimeFilter"
          },
          "type": "array"
        },
        "customWeightsMetadata": {
          "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.",
          "$ref": "GoogleCloudContentwarehouseV1CustomWeightsMetadata"
        },
        "customPropertyFilter": {
          "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`",
          "type": "string",
          "deprecated": true
        },
        "documentNameFilter": {
          "items": {
            "type": "string"
          },
          "description": "Search the documents in the list. Format: projects/{project_number}/locations/{location}/documents/{document_id}.",
          "type": "array"
        },
        "folderNameFilter": {
          "description": "Search all the documents under this specified folder. Format: projects/{project_number}/locations/{location}/documents/{document_id}.",
          "type": "string"
        },
        "propertyFilter": {
          "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.",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1PropertyFilter"
          }
        },
        "fileTypeFilter": {
          "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.",
          "$ref": "GoogleCloudContentwarehouseV1FileTypeFilter"
        },
        "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": {
          "type": "string",
          "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."
        }
      },
      "id": "GoogleCloudContentwarehouseV1DocumentQuery"
    },
    "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": {
          "type": "string",
          "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`"
        }
      },
      "description": "Image Quality Defects",
      "id": "GoogleCloudDocumentaiV1DocumentPageImageQualityScoresDetectedDefect",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1SetAclResponse": {
      "type": "object",
      "properties": {
        "metadata": {
          "$ref": "GoogleCloudContentwarehouseV1ResponseMetadata",
          "description": "Additional information for the API invocation, such as the request tracking id."
        },
        "policy": {
          "description": "The policy will be attached to a resource (e.g. projecct, document).",
          "$ref": "GoogleIamV1Policy"
        }
      },
      "id": "GoogleCloudContentwarehouseV1SetAclResponse",
      "description": "Response message for DocumentService.SetAcl."
    },
    "GoogleCloudContentwarehouseV1CloudAIDocumentOption": {
      "properties": {
        "enableEntitiesConversions": {
          "description": "Whether to convert all the entities to properties.",
          "type": "boolean"
        },
        "customizedEntitiesPropertiesConversions": {
          "description": "If set, only selected entities will be converted to properties.",
          "type": "object",
          "additionalProperties": {
            "type": "string"
          }
        }
      },
      "description": "Request Option for processing Cloud AI Document in CW Document.",
      "id": "GoogleCloudContentwarehouseV1CloudAIDocumentOption",
      "type": "object"
    },
    "GoogleCloudDocumentaiV1DocumentPageDetectedBarcode": {
      "description": "A detected barcode.",
      "properties": {
        "layout": {
          "description": "Layout for DetectedBarcode.",
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout"
        },
        "barcode": {
          "description": "Detailed barcode information of the DetectedBarcode.",
          "$ref": "GoogleCloudDocumentaiV1Barcode"
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentPageDetectedBarcode",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1UpdateDocumentMetadata": {
      "id": "GoogleCloudContentwarehouseV1UpdateDocumentMetadata",
      "description": "Metadata object for UpdateDocument request (currently empty).",
      "type": "object",
      "properties": {}
    },
    "GoogleCloudContentwarehouseV1EnumArray": {
      "type": "object",
      "description": "Enum values.",
      "properties": {
        "values": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "List of enum values."
        }
      },
      "id": "GoogleCloudContentwarehouseV1EnumArray"
    },
    "GoogleCloudContentwarehouseV1ActionExecutorOutput": {
      "description": "Represents the output of the Action Executor.",
      "type": "object",
      "properties": {
        "ruleActionsPairs": {
          "description": "List of rule and corresponding actions result.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1RuleActionsPair"
          }
        }
      },
      "id": "GoogleCloudContentwarehouseV1ActionExecutorOutput"
    },
    "CloudAiPlatformTenantresourceInfraSpannerConfig": {
      "type": "object",
      "properties": {
        "createDatabaseOptions": {
          "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.",
          "$ref": "CloudAiPlatformTenantresourceInfraSpannerConfigCreateDatabaseOptions"
        },
        "spannerUniverse": {
          "description": "Input [Required]. Every database in Spanner can be identified by the following path name: /span//:",
          "type": "string"
        },
        "sdlBundlePath": {
          "description": "Input [Required]. The file path to the spanner SDL bundle.",
          "type": "string"
        },
        "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"
        },
        "spannerNamespace": {
          "type": "string"
        },
        "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"
        },
        "spannerLocalNamePrefix": {
          "type": "string"
        }
      },
      "description": "The configuration for a spanner database provisioning. Next ID: 8",
      "id": "CloudAiPlatformTenantresourceInfraSpannerConfig"
    },
    "GoogleCloudContentwarehouseV1PropertyFilter": {
      "id": "GoogleCloudContentwarehouseV1PropertyFilter",
      "properties": {
        "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"
        },
        "documentSchemaName": {
          "type": "string",
          "description": "The Document schema name Document.document_schema_name. Format: projects/{project_number}/locations/{location}/documentSchemas/{document_schema_id}."
        }
      },
      "type": "object"
    },
    "CloudAiPlatformTenantresourceTenantResource": {
      "description": "A collection of tenant resources.",
      "id": "CloudAiPlatformTenantresourceTenantResource",
      "properties": {
        "p4ServiceAccounts": {
          "items": {
            "$ref": "CloudAiPlatformTenantresourceServiceAccountIdentity"
          },
          "description": "A list of P4 service accounts (go/p4sa) to provision or deprovision.",
          "type": "array"
        },
        "tenantProjectResources": {
          "items": {
            "$ref": "CloudAiPlatformTenantresourceTenantProjectResource"
          },
          "type": "array",
          "description": "A list of tenant projects and tenant resources to provision or deprovision."
        }
      },
      "type": "object"
    },
    "GoogleCloudDocumentaiV1DocumentPageParagraph": {
      "id": "GoogleCloudDocumentaiV1DocumentPageParagraph",
      "properties": {
        "provenance": {
          "deprecated": true,
          "description": "The history of this annotation.",
          "$ref": "GoogleCloudDocumentaiV1DocumentProvenance"
        },
        "layout": {
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout",
          "description": "Layout for Paragraph."
        },
        "detectedLanguages": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage"
          },
          "type": "array",
          "description": "A list of detected languages together with confidence."
        }
      },
      "description": "A collection of lines that a human would perceive as a paragraph.",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1PropertyDefinition": {
      "description": "Defines the metadata for a schema property.",
      "id": "GoogleCloudContentwarehouseV1PropertyDefinition",
      "properties": {
        "mapTypeOptions": {
          "description": "Map property.",
          "$ref": "GoogleCloudContentwarehouseV1MapTypeOptions"
        },
        "textTypeOptions": {
          "description": "Text/string property.",
          "$ref": "GoogleCloudContentwarehouseV1TextTypeOptions"
        },
        "integerTypeOptions": {
          "description": "Integer property.",
          "$ref": "GoogleCloudContentwarehouseV1IntegerTypeOptions"
        },
        "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"
        },
        "isFilterable": {
          "type": "boolean",
          "description": "Whether the property can be filtered. If this is a sub-property, all the parent properties must be marked filterable."
        },
        "timestampTypeOptions": {
          "$ref": "GoogleCloudContentwarehouseV1TimestampTypeOptions",
          "description": "Timestamp property. It is not supported by CMEK compliant deployment."
        },
        "retrievalImportance": {
          "type": "string",
          "enumDescriptions": [
            "No importance specified. Default medium importance.",
            "Highest importance.",
            "Higher importance.",
            "High importance.",
            "Medium importance.",
            "Low importance (negative).",
            "Lowest importance (negative)."
          ],
          "description": "The retrieval importance of the property during search.",
          "enum": [
            "RETRIEVAL_IMPORTANCE_UNSPECIFIED",
            "HIGHEST",
            "HIGHER",
            "HIGH",
            "MEDIUM",
            "LOW",
            "LOWEST"
          ]
        },
        "name": {
          "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 .",
          "type": "string"
        },
        "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"
        },
        "schemaSources": {
          "description": "The mapping information between this property to another schema source.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1PropertyDefinitionSchemaSource"
          }
        },
        "enumTypeOptions": {
          "$ref": "GoogleCloudContentwarehouseV1EnumTypeOptions",
          "description": "Enum/categorical property."
        },
        "propertyTypeOptions": {
          "description": "Nested structured data property.",
          "$ref": "GoogleCloudContentwarehouseV1PropertyTypeOptions"
        },
        "floatTypeOptions": {
          "description": "Float property.",
          "$ref": "GoogleCloudContentwarehouseV1FloatTypeOptions"
        },
        "dateTimeTypeOptions": {
          "description": "Date time property. It is not supported by CMEK compliant deployment.",
          "$ref": "GoogleCloudContentwarehouseV1DateTimeTypeOptions"
        },
        "displayName": {
          "type": "string",
          "description": "The display-name for the property, used for front-end."
        },
        "isSearchable": {
          "description": "Indicates that the property should be included in a global search.",
          "type": "boolean"
        },
        "isRepeatable": {
          "type": "boolean",
          "description": "Whether the property can have multiple values."
        }
      },
      "type": "object"
    },
    "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTextBlock": {
      "description": "Represents a text type block.",
      "type": "object",
      "properties": {
        "blocks": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlock"
          },
          "description": "A text block could further have child blocks. Repeated blocks support further hierarchies and nested blocks."
        },
        "type": {
          "type": "string",
          "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`."
        },
        "text": {
          "type": "string",
          "description": "Text content stored in the block."
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTextBlock"
    },
    "GoogleCloudContentwarehouseV1TimeFilter": {
      "id": "GoogleCloudContentwarehouseV1TimeFilter",
      "properties": {
        "timeRange": {
          "$ref": "GoogleTypeInterval"
        },
        "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."
          ]
        }
      },
      "description": "Filter on create timestamp or update timestamp of documents.",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1PropertyTypeOptions": {
      "properties": {
        "propertyDefinitions": {
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1PropertyDefinition"
          },
          "type": "array",
          "description": "Required. List of property definitions."
        }
      },
      "type": "object",
      "description": "Configurations for a nested structured data property.",
      "id": "GoogleCloudContentwarehouseV1PropertyTypeOptions"
    },
    "GoogleCloudContentwarehouseV1HistogramQueryPropertyNameFilter": {
      "type": "object",
      "properties": {
        "yAxis": {
          "type": "string",
          "enumDescriptions": [
            "Count the documents per property name.",
            "Count the properties per property name."
          ],
          "enum": [
            "HISTOGRAM_YAXIS_DOCUMENT",
            "HISTOGRAM_YAXIS_PROPERTY"
          ],
          "description": "By default, the y_axis is HISTOGRAM_YAXIS_DOCUMENT if this field is not set."
        },
        "documentSchemas": {
          "items": {
            "type": "string"
          },
          "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}.",
          "type": "array"
        },
        "propertyNames": {
          "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",
          "items": {
            "type": "string"
          }
        }
      },
      "id": "GoogleCloudContentwarehouseV1HistogramQueryPropertyNameFilter"
    },
    "GoogleCloudContentwarehouseV1EnumTypeOptions": {
      "description": "Configurations for an enum/categorical property.",
      "id": "GoogleCloudContentwarehouseV1EnumTypeOptions",
      "type": "object",
      "properties": {
        "validationCheckDisabled": {
          "type": "boolean",
          "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."
        },
        "possibleValues": {
          "items": {
            "type": "string"
          },
          "description": "Required. List of possible enum values.",
          "type": "array"
        }
      }
    },
    "CloudAiPlatformTenantresourceServiceAccountIdentity": {
      "properties": {
        "serviceAccountEmail": {
          "type": "string",
          "description": "Output only. The service account email that has been created."
        },
        "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"
        }
      },
      "id": "CloudAiPlatformTenantresourceServiceAccountIdentity",
      "description": "The identity to configure a service account.",
      "type": "object"
    },
    "GoogleCloudDocumentaiV1Document": {
      "type": "object",
      "id": "GoogleCloudDocumentaiV1Document",
      "properties": {
        "text": {
          "type": "string",
          "description": "Optional. UTF-8 encoded text in reading order from the document."
        },
        "textChanges": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentTextChange"
          },
          "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."
        },
        "chunkedDocument": {
          "description": "Document chunked based on chunking config.",
          "$ref": "GoogleCloudDocumentaiV1DocumentChunkedDocument"
        },
        "textStyles": {
          "deprecated": true,
          "description": "Styles for the Document.text.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentStyle"
          },
          "type": "array"
        },
        "pages": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPage"
          },
          "description": "Visual page layout for the Document.",
          "type": "array"
        },
        "revisions": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentRevision"
          },
          "description": "Placeholder. Revision history of this document.",
          "type": "array"
        },
        "entities": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentEntity"
          },
          "description": "A list of entities detected on Document.text. For document shards, entities in this list may cross shard boundaries."
        },
        "entityRelations": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentEntityRelation"
          },
          "description": "Placeholder. Relationship among Document.entities."
        },
        "documentLayout": {
          "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayout",
          "description": "Parsed layout of the document."
        },
        "error": {
          "description": "Any error that occurred while processing this document.",
          "$ref": "GoogleRpcStatus"
        },
        "mimeType": {
          "type": "string",
          "description": "An IANA published [media type (MIME type)](https://www.iana.org/assignments/media-types/media-types.xhtml)."
        },
        "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"
        },
        "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."
        },
        "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)."
        }
      },
      "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."
    },
    "GoogleCloudContentwarehouseV1HistogramQuery": {
      "description": "The histogram request.",
      "type": "object",
      "properties": {
        "histogramQuery": {
          "description": "An expression specifies a histogram request against matching documents for searches. See SearchDocumentsRequest.histogram_queries for details about syntax.",
          "type": "string"
        },
        "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"
        },
        "requirePreciseResultSize": {
          "type": "boolean",
          "description": "Controls if the histogram query requires the return of a precise count. Enable this flag may adversely impact performance. Defaults to true."
        }
      },
      "id": "GoogleCloudContentwarehouseV1HistogramQuery"
    },
    "GoogleCloudDocumentaiV1DocumentPageToken": {
      "description": "A detected token.",
      "id": "GoogleCloudDocumentaiV1DocumentPageToken",
      "properties": {
        "detectedLanguages": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage"
          },
          "type": "array",
          "description": "A list of detected languages together with confidence."
        },
        "styleInfo": {
          "$ref": "GoogleCloudDocumentaiV1DocumentPageTokenStyleInfo",
          "description": "Text style attributes."
        },
        "detectedBreak": {
          "description": "Detected break at the end of a Token.",
          "$ref": "GoogleCloudDocumentaiV1DocumentPageTokenDetectedBreak"
        },
        "provenance": {
          "description": "The history of this annotation.",
          "deprecated": true,
          "$ref": "GoogleCloudDocumentaiV1DocumentProvenance"
        },
        "layout": {
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout",
          "description": "Layout for Token."
        }
      },
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1RunPipelineMetadataGcsIngestPipelineMetadata": {
      "id": "GoogleCloudContentwarehouseV1RunPipelineMetadataGcsIngestPipelineMetadata",
      "properties": {
        "inputPath": {
          "type": "string",
          "description": "The input Cloud Storage folder in this pipeline. Format: `gs:///`."
        }
      },
      "description": "The metadata message for GcsIngest pipeline.",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1ListLinkedTargetsResponse": {
      "description": "Response message for DocumentLinkService.ListLinkedTargets.",
      "type": "object",
      "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."
        },
        "documentLinks": {
          "type": "array",
          "description": "Target document-links.",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1DocumentLink"
          }
        }
      },
      "id": "GoogleCloudContentwarehouseV1ListLinkedTargetsResponse"
    },
    "GoogleCloudContentwarehouseV1beta1InitializeProjectResponse": {
      "id": "GoogleCloudContentwarehouseV1beta1InitializeProjectResponse",
      "type": "object",
      "properties": {
        "message": {
          "type": "string",
          "description": "The message of the project initialization process."
        },
        "state": {
          "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."
          ],
          "enum": [
            "STATE_UNSPECIFIED",
            "SUCCEEDED",
            "FAILED",
            "CANCELLED",
            "RUNNING"
          ],
          "description": "The state of the project initialization process.",
          "type": "string"
        }
      },
      "description": "Response message for projectService.InitializeProject"
    },
    "GoogleCloudContentwarehouseV1FetchAclRequest": {
      "id": "GoogleCloudContentwarehouseV1FetchAclRequest",
      "description": "Request message for DocumentService.FetchAcl",
      "properties": {
        "requestMetadata": {
          "description": "The meta information collected about the end user, used to enforce access control for the service.",
          "$ref": "GoogleCloudContentwarehouseV1RequestMetadata"
        },
        "projectOwner": {
          "description": "For Get Project ACL only. Authorization check for end user will be ignored when project_owner=true.",
          "type": "boolean"
        }
      },
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1GcsIngestPipeline": {
      "id": "GoogleCloudContentwarehouseV1GcsIngestPipeline",
      "type": "object",
      "properties": {
        "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"
        },
        "pipelineConfig": {
          "$ref": "GoogleCloudContentwarehouseV1IngestPipelineConfig",
          "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."
        },
        "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."
        },
        "inputPath": {
          "description": "The input Cloud Storage folder. All files under this folder will be imported to Document Warehouse. Format: `gs:///`.",
          "type": "string"
        },
        "processorType": {
          "description": "The Doc AI processor type name. Only used when the format of ingested files is Doc AI Document proto format.",
          "type": "string"
        }
      },
      "description": "The configuration of the Cloud Storage Ingestion pipeline."
    },
    "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunkChunkPageHeader": {
      "description": "Represents the page header associated with the chunk.",
      "properties": {
        "pageSpan": {
          "description": "Page span of the header.",
          "$ref": "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunkChunkPageSpan"
        },
        "text": {
          "type": "string",
          "description": "Header in text format."
        }
      },
      "type": "object",
      "id": "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunkChunkPageHeader"
    },
    "GoogleTypeMoney": {
      "description": "Represents an amount of money with its currency type.",
      "properties": {
        "currencyCode": {
          "description": "The three-letter currency code defined in ISO 4217.",
          "type": "string"
        },
        "units": {
          "description": "The whole units of the amount. For example if `currencyCode` is `\"USD\"`, then 1 unit is one US dollar.",
          "format": "int64",
          "type": "string"
        },
        "nanos": {
          "type": "integer",
          "format": "int32",
          "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."
        }
      },
      "id": "GoogleTypeMoney",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1RunPipelineRequest": {
      "description": "Request message for DocumentService.RunPipeline.",
      "id": "GoogleCloudContentwarehouseV1RunPipelineRequest",
      "properties": {
        "gcsIngestPipeline": {
          "description": "Cloud Storage ingestion pipeline.",
          "$ref": "GoogleCloudContentwarehouseV1GcsIngestPipeline"
        },
        "exportCdwPipeline": {
          "$ref": "GoogleCloudContentwarehouseV1ExportToCdwPipeline",
          "description": "Export docuemnts from Document Warehouse to CDW for training purpose."
        },
        "gcsIngestWithDocAiProcessorsPipeline": {
          "$ref": "GoogleCloudContentwarehouseV1GcsIngestWithDocAiProcessorsPipeline",
          "description": "Use DocAI processors to process documents in Cloud Storage and ingest them to Document Warehouse."
        },
        "processWithDocAiPipeline": {
          "$ref": "GoogleCloudContentwarehouseV1ProcessWithDocAiPipeline",
          "description": "Use a DocAI processor to process documents in Document Warehouse, and re-ingest the updated results into Document Warehouse."
        },
        "requestMetadata": {
          "$ref": "GoogleCloudContentwarehouseV1RequestMetadata",
          "description": "The meta information collected about the end user, used to enforce access control for the service."
        }
      },
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1IngestPipelineConfig": {
      "properties": {
        "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."
        },
        "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"
        },
        "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"
        },
        "folder": {
          "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}`",
          "type": "string"
        }
      },
      "id": "GoogleCloudContentwarehouseV1IngestPipelineConfig",
      "description": "The ingestion pipeline config.",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1Value": {
      "properties": {
        "stringValue": {
          "type": "string",
          "description": "Represents a string value."
        },
        "datetimeValue": {
          "description": "Represents a datetime value.",
          "$ref": "GoogleTypeDateTime"
        },
        "booleanValue": {
          "type": "boolean",
          "description": "Represents a boolean value."
        },
        "timestampValue": {
          "description": "Represents a timestamp value.",
          "$ref": "GoogleCloudContentwarehouseV1TimestampValue"
        },
        "floatValue": {
          "format": "float",
          "description": "Represents a float value.",
          "type": "number"
        },
        "enumValue": {
          "description": "Represents an enum value.",
          "$ref": "GoogleCloudContentwarehouseV1EnumValue"
        },
        "intValue": {
          "format": "int32",
          "description": "Represents a integer value.",
          "type": "integer"
        }
      },
      "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.",
      "id": "GoogleCloudContentwarehouseV1Value",
      "type": "object"
    },
    "CloudAiPlatformTenantresourceGcsBucketConfig": {
      "description": "The identity to configure a GCS bucket.",
      "type": "object",
      "id": "CloudAiPlatformTenantresourceGcsBucketConfig",
      "properties": {
        "entityName": {
          "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.",
          "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."
        },
        "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"
        },
        "admins": {
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "ttlDays": {
          "format": "int32",
          "description": "Input/Output [Optional]. Only needed when the content in bucket need to be garbage collected within some amount of days.",
          "type": "integer"
        },
        "viewers": {
          "description": "Input/Output [Required]. IAM roles (viewer/admin) put on the bucket.",
          "items": {
            "type": "string"
          },
          "type": "array"
        }
      }
    },
    "GoogleCloudContentwarehouseV1IntegerArray": {
      "properties": {
        "values": {
          "description": "List of integer values.",
          "type": "array",
          "items": {
            "type": "integer",
            "format": "int32"
          }
        }
      },
      "id": "GoogleCloudContentwarehouseV1IntegerArray",
      "description": "Integer values.",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1CreateDocumentLinkRequest": {
      "type": "object",
      "properties": {
        "requestMetadata": {
          "description": "The meta information collected about the document creator, used to enforce access control for the service.",
          "$ref": "GoogleCloudContentwarehouseV1RequestMetadata"
        },
        "documentLink": {
          "description": "Required. Document links associated with the source documents (source_document_id).",
          "$ref": "GoogleCloudContentwarehouseV1DocumentLink"
        }
      },
      "id": "GoogleCloudContentwarehouseV1CreateDocumentLinkRequest",
      "description": "Request message for DocumentLinkService.CreateDocumentLink."
    },
    "CloudAiPlatformTenantresourceCloudSqlInstanceConfig": {
      "type": "object",
      "properties": {
        "slmInstanceName": {
          "type": "string",
          "description": "Output only. The SLM instance's full resource name."
        },
        "cloudSqlInstanceName": {
          "description": "Input/Output [Optional]. The CloudSQL instance name within SLM instance. If not set, a random UUIC will be generated as instance name.",
          "type": "string"
        },
        "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": {
          "type": "string",
          "description": "Input [Required]. The SLM instance type to provision CloudSQL."
        },
        "slmInstanceTemplate": {
          "type": "string",
          "description": "Input [Required]. The SLM instance template to provision CloudSQL."
        },
        "mdbRolesForCorpAccess": {
          "items": {
            "type": "string"
          },
          "description": "Input [Optional]. MDB roles for corp access to CloudSQL instance.",
          "type": "array"
        },
        "cloudSqlInstanceConnectionName": {
          "description": "Output only. The CloudSQL instance connection name.",
          "type": "string"
        }
      },
      "description": "The identity to configure a CloudSQL instance provisioned via SLM Terraform.",
      "id": "CloudAiPlatformTenantresourceCloudSqlInstanceConfig"
    },
    "GoogleCloudDocumentaiV1DocumentStyle": {
      "description": "Annotation for common text style attributes. This adheres to CSS conventions as much as possible.",
      "id": "GoogleCloudDocumentaiV1DocumentStyle",
      "type": "object",
      "properties": {
        "color": {
          "$ref": "GoogleTypeColor",
          "description": "Text color."
        },
        "textStyle": {
          "type": "string",
          "description": "[Text style](https://www.w3schools.com/cssref/pr_font_font-style.asp). Possible values are `normal`, `italic`, and `oblique`."
        },
        "textDecoration": {
          "description": "[Text decoration](https://www.w3schools.com/cssref/pr_text_text-decoration.asp). Follows CSS standard. ",
          "type": "string"
        },
        "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"
        },
        "textAnchor": {
          "$ref": "GoogleCloudDocumentaiV1DocumentTextAnchor",
          "description": "Text anchor indexing into the Document.text."
        },
        "fontSize": {
          "description": "Font size.",
          "$ref": "GoogleCloudDocumentaiV1DocumentStyleFontSize"
        },
        "fontWeight": {
          "description": "[Font weight](https://www.w3schools.com/cssref/pr_font_weight.asp). Possible values are `normal`, `bold`, `bolder`, and `lighter`.",
          "type": "string"
        }
      }
    },
    "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutListEntry": {
      "id": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutListEntry",
      "type": "object",
      "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.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlock"
          },
          "type": "array"
        }
      }
    },
    "GoogleCloudDocumentaiV1DocumentRevisionHumanReview": {
      "properties": {
        "stateMessage": {
          "type": "string",
          "description": "A message providing more details about the current state of processing. For example, the rejection reason when the state is `rejected`."
        },
        "state": {
          "type": "string",
          "description": "Human review state. e.g. `requested`, `succeeded`, `rejected`."
        }
      },
      "type": "object",
      "id": "GoogleCloudDocumentaiV1DocumentRevisionHumanReview",
      "description": "Human Review information of the document."
    },
    "GoogleCloudContentwarehouseV1DataUpdateAction": {
      "type": "object",
      "properties": {
        "entries": {
          "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.",
          "additionalProperties": {
            "type": "string"
          },
          "type": "object"
        }
      },
      "description": "Represents the action responsible for properties update operations.",
      "id": "GoogleCloudContentwarehouseV1DataUpdateAction"
    },
    "GoogleCloudDocumentaiV1DocumentPageTokenDetectedBreak": {
      "description": "Detected break at the end of a Token.",
      "properties": {
        "type": {
          "enumDescriptions": [
            "Unspecified break type.",
            "A single whitespace.",
            "A wider whitespace.",
            "A hyphen that indicates that a token has been split across lines."
          ],
          "description": "Detected break type.",
          "enum": [
            "TYPE_UNSPECIFIED",
            "SPACE",
            "WIDE_SPACE",
            "HYPHEN"
          ],
          "type": "string"
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentPageTokenDetectedBreak",
      "type": "object"
    },
    "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTableBlock": {
      "type": "object",
      "description": "Represents a table type block.",
      "id": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTableBlock",
      "properties": {
        "caption": {
          "description": "Table caption/title.",
          "type": "string"
        },
        "bodyRows": {
          "description": "Body rows containing main table content.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTableRow"
          }
        },
        "headerRows": {
          "description": "Header rows at the top of the table.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTableRow"
          },
          "type": "array"
        }
      }
    },
    "GoogleCloudDocumentaiV1DocumentProvenance": {
      "description": "Structure to identify provenance relationships between annotations in different revisions.",
      "type": "object",
      "id": "GoogleCloudDocumentaiV1DocumentProvenance",
      "properties": {
        "id": {
          "deprecated": true,
          "format": "int32",
          "description": "The Id of this operation. Needs to be unique within the scope of the revision.",
          "type": "integer"
        },
        "parents": {
          "description": "References to the original elements that are replaced.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentProvenanceParent"
          },
          "type": "array"
        },
        "revision": {
          "description": "The index of the revision that produced this element.",
          "deprecated": true,
          "format": "int32",
          "type": "integer"
        },
        "type": {
          "description": "The type of provenance operation.",
          "type": "string",
          "enum": [
            "OPERATION_TYPE_UNSPECIFIED",
            "ADD",
            "REMOVE",
            "UPDATE",
            "REPLACE",
            "EVAL_REQUESTED",
            "EVAL_APPROVED",
            "EVAL_SKIPPED"
          ],
          "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."
          ],
          "enumDeprecated": [
            false,
            false,
            false,
            false,
            false,
            true,
            true,
            true
          ]
        }
      }
    },
    "GoogleCloudDocumentaiV1DocumentPageTable": {
      "properties": {
        "provenance": {
          "deprecated": true,
          "$ref": "GoogleCloudDocumentaiV1DocumentProvenance",
          "description": "The history of this table."
        },
        "detectedLanguages": {
          "description": "A list of detected languages together with confidence.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage"
          }
        },
        "bodyRows": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageTableTableRow"
          },
          "description": "Body rows of the table."
        },
        "layout": {
          "description": "Layout for Table.",
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout"
        },
        "headerRows": {
          "type": "array",
          "description": "Header rows of the table.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageTableTableRow"
          }
        }
      },
      "type": "object",
      "description": "A table representation similar to HTML table structure.",
      "id": "GoogleCloudDocumentaiV1DocumentPageTable"
    },
    "GoogleCloudContentwarehouseV1RuleEngineOutput": {
      "type": "object",
      "description": "Records the output of Rule Engine including rule evaluation and actions result.",
      "properties": {
        "documentName": {
          "type": "string",
          "description": "Name of the document against which the rules and actions were evaluated."
        },
        "actionExecutorOutput": {
          "$ref": "GoogleCloudContentwarehouseV1ActionExecutorOutput",
          "description": "Output from Action Executor containing rule and corresponding actions execution result."
        },
        "ruleEvaluatorOutput": {
          "$ref": "GoogleCloudContentwarehouseV1RuleEvaluatorOutput",
          "description": "Output from Rule Evaluator containing matched, unmatched and invalid rules."
        }
      },
      "id": "GoogleCloudContentwarehouseV1RuleEngineOutput"
    },
    "GoogleCloudContentwarehouseV1UpdateDocumentRequest": {
      "type": "object",
      "description": "Request message for DocumentService.UpdateDocument.",
      "properties": {
        "document": {
          "description": "Required. The document to update.",
          "$ref": "GoogleCloudContentwarehouseV1Document"
        },
        "updateOptions": {
          "description": "Options for the update operation.",
          "$ref": "GoogleCloudContentwarehouseV1UpdateOptions"
        },
        "requestMetadata": {
          "$ref": "GoogleCloudContentwarehouseV1RequestMetadata",
          "description": "The meta information collected about the end user, used to enforce access control for the service."
        },
        "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"
        }
      },
      "id": "GoogleCloudContentwarehouseV1UpdateDocumentRequest"
    },
    "GoogleCloudContentwarehouseV1DocumentLink": {
      "id": "GoogleCloudContentwarehouseV1DocumentLink",
      "description": "A document-link between source and target document.",
      "type": "object",
      "properties": {
        "updateTime": {
          "type": "string",
          "readOnly": true,
          "format": "google-datetime",
          "description": "Output only. The time when the documentLink is last updated."
        },
        "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": {
          "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."
          ],
          "type": "string",
          "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.",
          "enum": [
            "STATE_UNSPECIFIED",
            "ACTIVE",
            "SOFT_DELETED"
          ]
        },
        "sourceDocumentReference": {
          "$ref": "GoogleCloudContentwarehouseV1DocumentReference",
          "description": "Document references of the source document."
        },
        "description": {
          "description": "Description of this document-link.",
          "type": "string"
        },
        "targetDocumentReference": {
          "$ref": "GoogleCloudContentwarehouseV1DocumentReference",
          "description": "Document references of the target document."
        },
        "createTime": {
          "description": "Output only. The time when the documentLink is created.",
          "format": "google-datetime",
          "type": "string",
          "readOnly": true
        }
      }
    },
    "GoogleProtobufEmpty": {
      "id": "GoogleProtobufEmpty",
      "properties": {},
      "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); }",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1WeightedSchemaProperty": {
      "description": "Specifies the schema property name.",
      "type": "object",
      "properties": {
        "propertyNames": {
          "items": {
            "type": "string"
          },
          "type": "array",
          "description": "The property definition names in the schema."
        },
        "documentSchemaName": {
          "description": "The document schema name.",
          "type": "string"
        }
      },
      "id": "GoogleCloudContentwarehouseV1WeightedSchemaProperty"
    },
    "GoogleTypeDate": {
      "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",
      "id": "GoogleTypeDate",
      "type": "object",
      "properties": {
        "year": {
          "description": "Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.",
          "type": "integer",
          "format": "int32"
        },
        "month": {
          "description": "Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.",
          "format": "int32",
          "type": "integer"
        },
        "day": {
          "type": "integer",
          "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.",
          "format": "int32"
        }
      }
    },
    "GoogleCloudDocumentaiV1DocumentEntityRelation": {
      "id": "GoogleCloudDocumentaiV1DocumentEntityRelation",
      "description": "Relationship between Entities.",
      "type": "object",
      "properties": {
        "relation": {
          "description": "Relationship description.",
          "type": "string"
        },
        "objectId": {
          "description": "Object entity id.",
          "type": "string"
        },
        "subjectId": {
          "type": "string",
          "description": "Subject entity id."
        }
      }
    },
    "GoogleCloudDocumentaiV1DocumentPageVisualElement": {
      "type": "object",
      "properties": {
        "detectedLanguages": {
          "description": "A list of detected languages together with confidence.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage"
          },
          "type": "array"
        },
        "layout": {
          "description": "Layout for VisualElement.",
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout"
        },
        "type": {
          "description": "Type of the VisualElement.",
          "type": "string"
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentPageVisualElement",
      "description": "Detected non-text visual elements e.g. checkbox, signature etc. on the page."
    },
    "GoogleCloudContentwarehouseV1SearchDocumentsRequest": {
      "description": "Request message for DocumentService.SearchDocuments.",
      "properties": {
        "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).",
          "type": "integer",
          "format": "int32"
        },
        "pageToken": {
          "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.",
          "type": "string"
        },
        "documentQuery": {
          "$ref": "GoogleCloudContentwarehouseV1DocumentQuery",
          "description": "Query used to search against documents (keyword, filters, etc.)."
        },
        "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"
        },
        "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": {
          "type": "integer",
          "format": "int32",
          "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."
        },
        "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": {
          "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')",
          "type": "array"
        },
        "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."
          ],
          "type": "string",
          "enum": [
            "TOTAL_RESULT_SIZE_UNSPECIFIED",
            "ESTIMATED_SIZE",
            "ACTUAL_SIZE"
          ],
          "description": "Controls if the search document request requires the return of a total size of matched documents. See SearchDocumentsResponse.total_size."
        },
        "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"
        }
      },
      "id": "GoogleCloudContentwarehouseV1SearchDocumentsRequest",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1QAResultHighlight": {
      "id": "GoogleCloudContentwarehouseV1QAResultHighlight",
      "description": "A text span in the search text snippet that represents a highlighted section (answer context, highly relevant sentence, etc.).",
      "properties": {
        "startIndex": {
          "format": "int32",
          "type": "integer",
          "description": "Start index of the highlight."
        },
        "endIndex": {
          "format": "int32",
          "type": "integer",
          "description": "End index of the highlight, exclusive."
        }
      },
      "type": "object"
    },
    "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": {
        "y": {
          "type": "number",
          "format": "float",
          "description": "Y coordinate (starts from the top of the image)."
        },
        "x": {
          "format": "float",
          "description": "X coordinate.",
          "type": "number"
        }
      },
      "id": "GoogleCloudDocumentaiV1NormalizedVertex",
      "type": "object"
    },
    "CloudAiPlatformTenantresourceTenantProjectResource": {
      "description": "The tenant project and tenant resources. Next ID: 10",
      "type": "object",
      "id": "CloudAiPlatformTenantresourceTenantProjectResource",
      "properties": {
        "cloudSqlInstances": {
          "type": "array",
          "description": "The CloudSQL instances that are provisioned under the tenant project.",
          "items": {
            "$ref": "CloudAiPlatformTenantresourceCloudSqlInstanceConfig"
          }
        },
        "infraSpannerConfigs": {
          "description": "The Infra Spanner databases that are provisioned under the tenant project. Note: this is an experimental feature.",
          "items": {
            "$ref": "CloudAiPlatformTenantresourceInfraSpannerConfig"
          },
          "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."
        },
        "tenantProjectId": {
          "type": "string",
          "description": "Output only. The tenant project ID that has been created."
        },
        "tenantProjectNumber": {
          "format": "int64",
          "type": "string",
          "description": "Output only. The tenant project number that has been created."
        },
        "gcsBuckets": {
          "type": "array",
          "description": "The GCS buckets that are provisioned under the tenant project.",
          "items": {
            "$ref": "CloudAiPlatformTenantresourceGcsBucketConfig"
          }
        },
        "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"
        },
        "iamPolicyBindings": {
          "type": "array",
          "items": {
            "$ref": "CloudAiPlatformTenantresourceIamPolicyBinding"
          },
          "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."
        },
        "tenantProjectConfig": {
          "$ref": "CloudAiPlatformTenantresourceTenantProjectConfig",
          "description": "The configurations of a tenant project."
        }
      }
    },
    "GoogleCloudDocumentaiV1BoundingPoly": {
      "id": "GoogleCloudDocumentaiV1BoundingPoly",
      "properties": {
        "vertices": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1Vertex"
          },
          "description": "The bounding polygon vertices."
        },
        "normalizedVertices": {
          "description": "The bounding polygon normalized vertices.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1NormalizedVertex"
          },
          "type": "array"
        }
      },
      "description": "A bounding polygon for the detected image annotation.",
      "type": "object"
    },
    "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutListBlock": {
      "type": "object",
      "description": "Represents a list type block.",
      "properties": {
        "listEntries": {
          "description": "List entries that constitute a list block.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutListEntry"
          },
          "type": "array"
        },
        "type": {
          "description": "Type of the list_entries (if exist). Available options are `ordered` and `unordered`.",
          "type": "string"
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutListBlock"
    },
    "GoogleCloudContentwarehouseV1ResponseMetadata": {
      "description": "Additional information returned to client, such as debugging information.",
      "id": "GoogleCloudContentwarehouseV1ResponseMetadata",
      "properties": {
        "requestId": {
          "description": "A unique id associated with this call. This id is logged for tracking purpose.",
          "type": "string"
        }
      },
      "type": "object"
    },
    "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"
    },
    "GoogleCloudDocumentaiV1DocumentTextAnchorTextSegment": {
      "id": "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",
      "properties": {
        "startIndex": {
          "type": "string",
          "description": "TextSegment start UTF-8 char index in the Document.text.",
          "format": "int64"
        },
        "endIndex": {
          "type": "string",
          "description": "TextSegment half open end UTF-8 char index in the Document.text.",
          "format": "int64"
        }
      }
    },
    "GoogleCloudContentwarehouseV1ListLinkedTargetsRequest": {
      "id": "GoogleCloudContentwarehouseV1ListLinkedTargetsRequest",
      "description": "Request message for DocumentLinkService.ListLinkedTargets.",
      "type": "object",
      "properties": {
        "requestMetadata": {
          "description": "The meta information collected about the document creator, used to enforce access control for the service.",
          "$ref": "GoogleCloudContentwarehouseV1RequestMetadata"
        }
      }
    },
    "GoogleCloudContentwarehouseV1Property": {
      "properties": {
        "integerValues": {
          "description": "Integer property values.",
          "$ref": "GoogleCloudContentwarehouseV1IntegerArray"
        },
        "mapProperty": {
          "description": "Map property values.",
          "$ref": "GoogleCloudContentwarehouseV1MapProperty"
        },
        "floatValues": {
          "description": "Float property values.",
          "$ref": "GoogleCloudContentwarehouseV1FloatArray"
        },
        "dateTimeValues": {
          "description": "Date time property values. It is not supported by CMEK compliant deployment.",
          "$ref": "GoogleCloudContentwarehouseV1DateTimeArray"
        },
        "textValues": {
          "$ref": "GoogleCloudContentwarehouseV1TextArray",
          "description": "String/text property values."
        },
        "name": {
          "type": "string",
          "description": "Required. Must match the name of a PropertyDefinition in the DocumentSchema."
        },
        "propertyValues": {
          "$ref": "GoogleCloudContentwarehouseV1PropertyArray",
          "description": "Nested structured data property values."
        },
        "timestampValues": {
          "$ref": "GoogleCloudContentwarehouseV1TimestampArray",
          "description": "Timestamp property values. It is not supported by CMEK compliant deployment."
        },
        "enumValues": {
          "description": "Enum property values.",
          "$ref": "GoogleCloudContentwarehouseV1EnumArray"
        }
      },
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1Property",
      "description": "Property of a document."
    },
    "GoogleCloudDocumentaiV1DocumentPageBlock": {
      "id": "GoogleCloudDocumentaiV1DocumentPageBlock",
      "properties": {
        "provenance": {
          "deprecated": true,
          "description": "The history of this annotation.",
          "$ref": "GoogleCloudDocumentaiV1DocumentProvenance"
        },
        "detectedLanguages": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage"
          },
          "description": "A list of detected languages together with confidence."
        },
        "layout": {
          "description": "Layout for Block.",
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout"
        }
      },
      "description": "A block has a set of lines (collected into paragraphs) that have a common line-spacing and orientation.",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1DateTimeArray": {
      "description": "DateTime values.",
      "type": "object",
      "properties": {
        "values": {
          "type": "array",
          "description": "List of datetime values. Both OffsetDateTime and ZonedDateTime are supported.",
          "items": {
            "$ref": "GoogleTypeDateTime"
          }
        }
      },
      "id": "GoogleCloudContentwarehouseV1DateTimeArray"
    },
    "GoogleLongrunningOperation": {
      "description": "This resource represents a long-running operation that is the result of a network API call.",
      "id": "GoogleLongrunningOperation",
      "type": "object",
      "properties": {
        "name": {
          "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}`.",
          "type": "string"
        },
        "error": {
          "$ref": "GoogleRpcStatus",
          "description": "The error result of the operation in case of failure or cancellation."
        },
        "response": {
          "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`.",
          "additionalProperties": {
            "type": "any",
            "description": "Properties of the object. Contains field @type with type URL."
          },
          "type": "object"
        },
        "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."
        },
        "metadata": {
          "additionalProperties": {
            "type": "any",
            "description": "Properties of the object. Contains field @type with type URL."
          },
          "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.",
          "type": "object"
        }
      }
    },
    "GoogleCloudContentwarehouseV1MergeFieldsOptions": {
      "type": "object",
      "description": "Options for merging updated fields.",
      "properties": {
        "replaceRepeatedFields": {
          "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.",
          "type": "boolean"
        },
        "replaceMessageFields": {
          "type": "boolean",
          "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."
        }
      },
      "id": "GoogleCloudContentwarehouseV1MergeFieldsOptions"
    },
    "GoogleCloudContentwarehouseV1InitializeProjectResponse": {
      "properties": {
        "message": {
          "type": "string",
          "description": "The message of the project initialization process."
        },
        "state": {
          "type": "string",
          "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."
          ],
          "enum": [
            "STATE_UNSPECIFIED",
            "SUCCEEDED",
            "FAILED",
            "CANCELLED",
            "RUNNING"
          ],
          "description": "The state of the project initialization process."
        }
      },
      "id": "GoogleCloudContentwarehouseV1InitializeProjectResponse",
      "type": "object",
      "description": "Response message for projectService.InitializeProject"
    },
    "GoogleCloudContentwarehouseV1DateTimeTypeOptions": {
      "type": "object",
      "properties": {},
      "description": "Configurations for a date time property.",
      "id": "GoogleCloudContentwarehouseV1DateTimeTypeOptions"
    },
    "GoogleCloudDocumentaiV1DocumentPageTokenStyleInfo": {
      "id": "GoogleCloudDocumentaiV1DocumentPageTokenStyleInfo",
      "properties": {
        "bold": {
          "type": "boolean",
          "description": "Whether the text is bold (equivalent to font_weight is at least `700`)."
        },
        "handwritten": {
          "type": "boolean",
          "description": "Whether the text is handwritten."
        },
        "fontType": {
          "description": "Name or style of the font.",
          "type": "string"
        },
        "backgroundColor": {
          "$ref": "GoogleTypeColor",
          "description": "Color of the background."
        },
        "superscript": {
          "description": "Whether the text is a superscript. This feature is not supported yet.",
          "type": "boolean"
        },
        "subscript": {
          "type": "boolean",
          "description": "Whether the text is a subscript. This feature is not supported yet."
        },
        "fontSize": {
          "description": "Font size in points (`1` point is `¹⁄₇₂` inches).",
          "format": "int32",
          "type": "integer"
        },
        "pixelFontSize": {
          "description": "Font size in pixels, equal to _unrounded font_size_ * _resolution_ ÷ `72.0`.",
          "type": "number",
          "format": "double"
        },
        "textColor": {
          "description": "Color of the text.",
          "$ref": "GoogleTypeColor"
        },
        "italic": {
          "type": "boolean",
          "description": "Whether the text is italic."
        },
        "fontWeight": {
          "description": "TrueType weight on a scale `100` (thin) to `1000` (ultra-heavy). Normal is `400`, bold is `700`.",
          "type": "integer",
          "format": "int32"
        },
        "smallcaps": {
          "type": "boolean",
          "description": "Whether the text is in small caps. This feature is not supported yet."
        },
        "letterSpacing": {
          "type": "number",
          "description": "Letter spacing in points.",
          "format": "double"
        },
        "strikeout": {
          "type": "boolean",
          "description": "Whether the text is strikethrough. This feature is not supported yet."
        },
        "underlined": {
          "description": "Whether the text is underlined.",
          "type": "boolean"
        }
      },
      "type": "object",
      "description": "Font and other text style attributes."
    },
    "GoogleCloudDocumentaiV1DocumentPageLayout": {
      "description": "Visual element describing a layout unit on a page.",
      "id": "GoogleCloudDocumentaiV1DocumentPageLayout",
      "type": "object",
      "properties": {
        "confidence": {
          "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]`.",
          "format": "float",
          "type": "number"
        },
        "textAnchor": {
          "description": "Text anchor indexing into the Document.text.",
          "$ref": "GoogleCloudDocumentaiV1DocumentTextAnchor"
        },
        "orientation": {
          "enum": [
            "ORIENTATION_UNSPECIFIED",
            "PAGE_UP",
            "PAGE_RIGHT",
            "PAGE_DOWN",
            "PAGE_LEFT"
          ],
          "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."
          ],
          "description": "Detected orientation for the Layout.",
          "type": "string"
        },
        "boundingPoly": {
          "description": "The bounding polygon for the Layout.",
          "$ref": "GoogleCloudDocumentaiV1BoundingPoly"
        }
      }
    },
    "GoogleCloudDocumentaiV1DocumentTextAnchor": {
      "type": "object",
      "id": "GoogleCloudDocumentaiV1DocumentTextAnchor",
      "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": {
          "description": "The text segments from the Document.text.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentTextAnchorTextSegment"
          },
          "type": "array"
        }
      },
      "description": "Text reference indexing into the Document.text."
    },
    "GoogleCloudContentwarehouseV1ListDocumentSchemasResponse": {
      "description": "Response message for DocumentSchemaService.ListDocumentSchemas.",
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1ListDocumentSchemasResponse",
      "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."
        },
        "documentSchemas": {
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1DocumentSchema"
          },
          "type": "array",
          "description": "The document schemas from the specified parent."
        }
      }
    },
    "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": {
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1Rule"
          },
          "description": "List of rules given by the customer.",
          "type": "array"
        },
        "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."
        }
      },
      "description": "Represents a set of rules from a single customer.",
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1RuleSet"
    },
    "GoogleCloudContentwarehouseV1RequestMetadata": {
      "description": "Meta information is used to improve the performance of the service.",
      "properties": {
        "userInfo": {
          "description": "Provides user unique identification and groups information.",
          "$ref": "GoogleCloudContentwarehouseV1UserInfo"
        }
      },
      "id": "GoogleCloudContentwarehouseV1RequestMetadata",
      "type": "object"
    },
    "GoogleCloudDocumentaiV1DocumentPageMatrix": {
      "type": "object",
      "description": "Representation for transformation matrix, intended to be compatible and used with OpenCV format for image manipulation.",
      "id": "GoogleCloudDocumentaiV1DocumentPageMatrix",
      "properties": {
        "type": {
          "type": "integer",
          "format": "int32",
          "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"
        },
        "data": {
          "type": "string",
          "description": "The matrix data.",
          "format": "byte"
        },
        "cols": {
          "format": "int32",
          "description": "Number of columns in the matrix.",
          "type": "integer"
        },
        "rows": {
          "format": "int32",
          "type": "integer",
          "description": "Number of rows in the matrix."
        }
      }
    },
    "GoogleCloudContentwarehouseV1UserInfo": {
      "description": "The user information.",
      "type": "object",
      "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",
          "items": {
            "type": "string"
          },
          "description": "The unique group identifications which the user is belong to. The format is \"group:yyyy@example.com\";"
        }
      }
    },
    "GoogleCloudContentwarehouseV1UpdateOptions": {
      "description": "Options for Update operations.",
      "id": "GoogleCloudContentwarehouseV1UpdateOptions",
      "type": "object",
      "properties": {
        "mergeFieldsOptions": {
          "description": "Options for merging.",
          "$ref": "GoogleCloudContentwarehouseV1MergeFieldsOptions"
        },
        "updateMask": {
          "description": "Field mask for merging Document fields. For the `FieldMask` definition, see https://developers.google.com/protocol-buffers/docs/reference/google.protobuf#fieldmask",
          "format": "google-fieldmask",
          "type": "string"
        },
        "updateType": {
          "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.",
          "type": "string",
          "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"
          ]
        }
      }
    },
    "GoogleIamV1AuditConfig": {
      "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.",
      "properties": {
        "auditLogConfigs": {
          "items": {
            "$ref": "GoogleIamV1AuditLogConfig"
          },
          "type": "array",
          "description": "The configuration for logging of each type of permission."
        },
        "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"
        }
      },
      "type": "object",
      "id": "GoogleIamV1AuditConfig"
    },
    "GoogleCloudDocumentaiV1DocumentPageAnchorPageRef": {
      "id": "GoogleCloudDocumentaiV1DocumentPageAnchorPageRef",
      "properties": {
        "layoutId": {
          "deprecated": true,
          "description": "Optional. Deprecated. Use PageRef.bounding_poly instead.",
          "type": "string"
        },
        "page": {
          "format": "int64",
          "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.",
          "type": "string"
        },
        "confidence": {
          "description": "Optional. Confidence of detected page element, if applicable. Range `[0, 1]`.",
          "type": "number",
          "format": "float"
        },
        "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."
          ],
          "type": "string",
          "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."
        }
      },
      "description": "Represents a weak reference to a page element within a document.",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1AccessControlAction": {
      "properties": {
        "operationType": {
          "enum": [
            "UNKNOWN",
            "ADD_POLICY_BINDING",
            "REMOVE_POLICY_BINDING",
            "REPLACE_POLICY_BINDING"
          ],
          "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"
          ]
        },
        "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"
        }
      },
      "id": "GoogleCloudContentwarehouseV1AccessControlAction",
      "description": "Represents the action responsible for access control list management operations.",
      "type": "object"
    },
    "GoogleRpcStatus": {
      "type": "object",
      "id": "GoogleRpcStatus",
      "properties": {
        "code": {
          "type": "integer",
          "format": "int32",
          "description": "The status code, which should be an enum value of google.rpc.Code."
        },
        "details": {
          "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use.",
          "items": {
            "type": "object",
            "additionalProperties": {
              "description": "Properties of the object. Contains field @type with type URL.",
              "type": "any"
            }
          },
          "type": "array"
        },
        "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"
        }
      },
      "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)."
    },
    "GoogleCloudContentwarehouseV1PropertyDefinitionSchemaSource": {
      "description": "The schema source information.",
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1PropertyDefinitionSchemaSource",
      "properties": {
        "name": {
          "type": "string",
          "description": "The schema name in the source."
        },
        "processorType": {
          "description": "The Doc AI processor type name.",
          "type": "string"
        }
      }
    },
    "GoogleCloudContentwarehouseV1RunPipelineMetadataProcessWithDocAiPipelineMetadata": {
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1RunPipelineMetadataProcessWithDocAiPipelineMetadata",
      "properties": {
        "processorInfo": {
          "$ref": "GoogleCloudContentwarehouseV1ProcessorInfo",
          "description": "The DocAI processor to process the documents with."
        },
        "documents": {
          "items": {
            "type": "string"
          },
          "type": "array",
          "description": "The input list of all the resource names of the documents to be processed."
        }
      },
      "description": "The metadata message for Process-with-DocAi pipeline."
    },
    "GoogleCloudDocumentaiV1DocumentPage": {
      "description": "A page in a Document.",
      "type": "object",
      "properties": {
        "formFields": {
          "description": "A list of visually detected form fields on the page.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageFormField"
          }
        },
        "imageQualityScores": {
          "description": "Image quality scores.",
          "$ref": "GoogleCloudDocumentaiV1DocumentPageImageQualityScores"
        },
        "transforms": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageMatrix"
          },
          "description": "Transformation matrices that were applied to the original document image to produce Page.image.",
          "type": "array"
        },
        "detectedBarcodes": {
          "description": "A list of detected barcodes.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedBarcode"
          },
          "type": "array"
        },
        "detectedLanguages": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage"
          },
          "description": "A list of detected languages together with confidence."
        },
        "visualElements": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageVisualElement"
          },
          "description": "A list of detected non-text visual elements e.g. checkbox, signature etc. on the page.",
          "type": "array"
        },
        "blocks": {
          "type": "array",
          "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.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageBlock"
          }
        },
        "tables": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageTable"
          },
          "description": "A list of visually detected tables on the page.",
          "type": "array"
        },
        "paragraphs": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageParagraph"
          },
          "description": "A list of visually detected text paragraphs on the page. A collection of lines that a human would perceive as a paragraph.",
          "type": "array"
        },
        "symbols": {
          "type": "array",
          "description": "A list of visually detected symbols on the page.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageSymbol"
          }
        },
        "dimension": {
          "$ref": "GoogleCloudDocumentaiV1DocumentPageDimension",
          "description": "Physical dimension of the page."
        },
        "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"
        },
        "layout": {
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout",
          "description": "Layout for the page."
        },
        "tokens": {
          "type": "array",
          "description": "A list of visually detected tokens on the page.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageToken"
          }
        },
        "pageNumber": {
          "format": "int32",
          "type": "integer",
          "description": "1-based index for current Page in a parent Document. Useful when a page is taken out of a Document for individual processing."
        },
        "provenance": {
          "$ref": "GoogleCloudDocumentaiV1DocumentProvenance",
          "deprecated": true,
          "description": "The history of this page."
        },
        "lines": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageLine"
          },
          "description": "A list of visually detected text lines on the page. A collection of tokens that a human would perceive as a line."
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentPage"
    },
    "GoogleCloudContentwarehouseV1RunPipelineMetadataExportToCdwPipelineMetadata": {
      "type": "object",
      "properties": {
        "docAiDataset": {
          "description": "The output CDW dataset resource name.",
          "type": "string"
        },
        "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"
          }
        }
      },
      "id": "GoogleCloudContentwarehouseV1RunPipelineMetadataExportToCdwPipelineMetadata",
      "description": "The metadata message for Export-to-CDW pipeline."
    },
    "GoogleCloudContentwarehouseV1RemoveFromFolderAction": {
      "type": "object",
      "properties": {
        "folder": {
          "description": "Name of the folder under which new document is to be added. Format: projects/{project_number}/locations/{location}/documents/{document_id}.",
          "type": "string"
        },
        "condition": {
          "description": "Condition of the action to be executed.",
          "type": "string"
        }
      },
      "description": "Represents the action responsible for remove a document from a specific folder.",
      "id": "GoogleCloudContentwarehouseV1RemoveFromFolderAction"
    },
    "GoogleCloudContentwarehouseV1TimestampValue": {
      "id": "GoogleCloudContentwarehouseV1TimestampValue",
      "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",
          "description": "Timestamp value",
          "type": "string"
        }
      },
      "type": "object",
      "description": "Timestamp value type."
    },
    "CloudAiPlatformTenantresourceTenantServiceAccountIdentity": {
      "id": "CloudAiPlatformTenantresourceTenantServiceAccountIdentity",
      "type": "object",
      "properties": {
        "serviceAccountEmail": {
          "description": "Output only. The email address of the generated service account.",
          "type": "string"
        },
        "serviceName": {
          "description": "Input/Output [Required]. The service that the service account belongs to. (e.g. cloudbuild.googleapis.com for GCB service accounts)",
          "type": "string"
        }
      },
      "description": "The identity of service accounts that have been explicitly created under tenant projects."
    },
    "GoogleCloudContentwarehouseV1DataValidationAction": {
      "description": "Represents the action responsible for data validation operations.",
      "id": "GoogleCloudContentwarehouseV1DataValidationAction",
      "properties": {
        "conditions": {
          "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.",
          "additionalProperties": {
            "type": "string"
          },
          "type": "object"
        }
      },
      "type": "object"
    },
    "GoogleIamV1AuditLogConfig": {
      "type": "object",
      "id": "GoogleIamV1AuditLogConfig",
      "properties": {
        "logType": {
          "enum": [
            "LOG_TYPE_UNSPECIFIED",
            "ADMIN_READ",
            "DATA_WRITE",
            "DATA_READ"
          ],
          "type": "string",
          "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."
        },
        "exemptedMembers": {
          "items": {
            "type": "string"
          },
          "description": "Specifies the identities that do not cause logging for this type of permission. Follows the same format of Binding.members.",
          "type": "array"
        }
      },
      "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."
    },
    "GoogleCloudContentwarehouseV1ActionOutput": {
      "properties": {
        "outputMessage": {
          "description": "Action execution output message.",
          "type": "string"
        },
        "actionState": {
          "enumDescriptions": [
            "The unknown state.",
            "State indicating action executed successfully.",
            "State indicating action failed.",
            "State indicating action timed out.",
            "State indicating action is pending."
          ],
          "enum": [
            "UNKNOWN",
            "ACTION_SUCCEEDED",
            "ACTION_FAILED",
            "ACTION_TIMED_OUT",
            "ACTION_PENDING"
          ],
          "description": "State of an action.",
          "type": "string"
        },
        "actionId": {
          "description": "ID of the action.",
          "type": "string"
        }
      },
      "description": "Represents the result of executing an action.",
      "id": "GoogleCloudContentwarehouseV1ActionOutput",
      "type": "object"
    },
    "GoogleTypeColor": {
      "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(''); }; // ...",
      "properties": {
        "red": {
          "format": "float",
          "description": "The amount of red in the color as a value in the interval [0, 1].",
          "type": "number"
        },
        "green": {
          "format": "float",
          "description": "The amount of green in the color as a value in the interval [0, 1].",
          "type": "number"
        },
        "blue": {
          "description": "The amount of blue in the color as a value in the interval [0, 1].",
          "format": "float",
          "type": "number"
        },
        "alpha": {
          "format": "float",
          "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)."
        }
      },
      "type": "object",
      "id": "GoogleTypeColor"
    },
    "GoogleCloudContentwarehouseV1ListRuleSetsResponse": {
      "properties": {
        "ruleSets": {
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1RuleSet"
          },
          "description": "The rule sets from the specified parent.",
          "type": "array"
        },
        "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."
        }
      },
      "id": "GoogleCloudContentwarehouseV1ListRuleSetsResponse",
      "type": "object",
      "description": "Response message for RuleSetService.ListRuleSets."
    },
    "GoogleCloudContentwarehouseV1FetchAclResponse": {
      "id": "GoogleCloudContentwarehouseV1FetchAclResponse",
      "properties": {
        "metadata": {
          "description": "Additional information for the API invocation, such as the request tracking id.",
          "$ref": "GoogleCloudContentwarehouseV1ResponseMetadata"
        },
        "policy": {
          "description": "The IAM policy.",
          "$ref": "GoogleIamV1Policy"
        }
      },
      "description": "Response message for DocumentService.FetchAcl.",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1PropertyArray": {
      "type": "object",
      "properties": {
        "properties": {
          "type": "array",
          "description": "List of property values.",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1Property"
          }
        }
      },
      "id": "GoogleCloudContentwarehouseV1PropertyArray",
      "description": "Property values."
    },
    "GoogleCloudDocumentaiV1DocumentEntityNormalizedValue": {
      "type": "object",
      "properties": {
        "booleanValue": {
          "type": "boolean",
          "description": "Boolean value. Can be used for entities with binary values, or for checkboxes."
        },
        "addressValue": {
          "description": "Postal address. See also: https://github.com/googleapis/googleapis/blob/master/google/type/postal_address.proto",
          "$ref": "GoogleTypePostalAddress"
        },
        "integerValue": {
          "description": "Integer value.",
          "format": "int32",
          "type": "integer"
        },
        "moneyValue": {
          "$ref": "GoogleTypeMoney",
          "description": "Money value. See also: https://github.com/googleapis/googleapis/blob/master/google/type/money.proto"
        },
        "datetimeValue": {
          "$ref": "GoogleTypeDateTime",
          "description": "DateTime value. Includes date, time, and timezone. See also: https://github.com/googleapis/googleapis/blob/master/google/type/datetime.proto"
        },
        "text": {
          "type": "string",
          "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."
        },
        "dateValue": {
          "description": "Date value. Includes year, month, day. See also: https://github.com/googleapis/googleapis/blob/master/google/type/date.proto",
          "$ref": "GoogleTypeDate"
        },
        "floatValue": {
          "description": "Float value.",
          "type": "number",
          "format": "float"
        }
      },
      "description": "Parsed and normalized entity value.",
      "id": "GoogleCloudDocumentaiV1DocumentEntityNormalizedValue"
    },
    "CloudAiPlatformTenantresourceIamPolicyBinding": {
      "id": "CloudAiPlatformTenantresourceIamPolicyBinding",
      "description": "The dynamic IAM bindings to be granted after tenant projects are created.",
      "type": "object",
      "properties": {
        "members": {
          "type": "array",
          "description": "Input/Output [Required]. The member service accounts with the roles above. Note: placeholders are same as the resource above.",
          "items": {
            "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."
        },
        "resourceType": {
          "description": "Input/Output [Required]. Specifies the type of resource that will be accessed by members.",
          "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: /// ///: ///@"
          ],
          "type": "string",
          "enum": [
            "RESOURCE_TYPE_UNSPECIFIED",
            "PROJECT",
            "SERVICE_ACCOUNT",
            "GCS_BUCKET",
            "SERVICE_CONSUMER",
            "AR_REPO"
          ]
        }
      }
    },
    "GoogleCloudContentwarehouseV1CreateDocumentMetadata": {
      "id": "GoogleCloudContentwarehouseV1CreateDocumentMetadata",
      "description": "Metadata object for CreateDocument request (currently empty).",
      "type": "object",
      "properties": {}
    },
    "GoogleCloudContentwarehouseV1SearchDocumentsResponseMatchingDocument": {
      "id": "GoogleCloudContentwarehouseV1SearchDocumentsResponseMatchingDocument",
      "properties": {
        "searchTextSnippet": {
          "type": "string",
          "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."
        },
        "matchedTokenPageIndices": {
          "type": "array",
          "items": {
            "type": "string",
            "format": "int64"
          },
          "description": "Return the 1-based page indices where those pages have one or more matched tokens."
        },
        "document": {
          "description": "Document that matches the specified SearchDocumentsRequest. This document only contains indexed metadata information.",
          "$ref": "GoogleCloudContentwarehouseV1Document"
        },
        "qaResult": {
          "$ref": "GoogleCloudContentwarehouseV1QAResult",
          "description": "Experimental. Additional result info if the question-answering feature is enabled."
        }
      },
      "type": "object",
      "description": "Document entry with metadata inside SearchDocumentsResponse"
    },
    "GoogleCloudDocumentaiV1DocumentPageFormField": {
      "properties": {
        "provenance": {
          "description": "The history of this annotation.",
          "$ref": "GoogleCloudDocumentaiV1DocumentProvenance"
        },
        "valueType": {
          "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`",
          "type": "string"
        },
        "correctedKeyText": {
          "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.",
          "type": "string"
        },
        "fieldValue": {
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout",
          "description": "Layout for the FormField value."
        },
        "fieldName": {
          "description": "Layout for the FormField name. e.g. `Address`, `Email`, `Grand total`, `Phone number`, etc.",
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout"
        },
        "correctedValueText": {
          "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.",
          "type": "string"
        },
        "valueDetectedLanguages": {
          "description": "A list of detected languages for value together with confidence.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage"
          }
        },
        "nameDetectedLanguages": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage"
          },
          "description": "A list of detected languages for name together with confidence."
        }
      },
      "id": "GoogleCloudDocumentaiV1DocumentPageFormField",
      "type": "object",
      "description": "A form field detected on the page."
    },
    "GoogleCloudContentwarehouseV1DeleteDocumentLinkRequest": {
      "properties": {
        "requestMetadata": {
          "description": "The meta information collected about the document creator, used to enforce access control for the service.",
          "$ref": "GoogleCloudContentwarehouseV1RequestMetadata"
        }
      },
      "type": "object",
      "description": "Request message for DocumentLinkService.DeleteDocumentLink.",
      "id": "GoogleCloudContentwarehouseV1DeleteDocumentLinkRequest"
    },
    "GoogleCloudContentwarehouseV1UpdateDocumentResponse": {
      "type": "object",
      "properties": {
        "metadata": {
          "$ref": "GoogleCloudContentwarehouseV1ResponseMetadata",
          "description": "Additional information for the API invocation, such as the request tracking id."
        },
        "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"
        },
        "document": {
          "description": "Updated document after executing update request.",
          "$ref": "GoogleCloudContentwarehouseV1Document"
        }
      },
      "id": "GoogleCloudContentwarehouseV1UpdateDocumentResponse",
      "description": "Response message for DocumentService.UpdateDocument."
    },
    "GoogleCloudContentwarehouseV1FileTypeFilter": {
      "type": "object",
      "description": "Filter for the specific types of documents returned.",
      "properties": {
        "fileType": {
          "type": "string",
          "enum": [
            "FILE_TYPE_UNSPECIFIED",
            "ALL",
            "FOLDER",
            "DOCUMENT",
            "ROOT_FOLDER"
          ],
          "description": "The type of files to return.",
          "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"
    },
    "GoogleApiServiceconsumermanagementV1BillingConfig": {
      "description": "Describes the billing configuration for a new tenant project.",
      "id": "GoogleApiServiceconsumermanagementV1BillingConfig",
      "properties": {
        "billingAccount": {
          "type": "string",
          "description": "Name of the billing account. For example `billingAccounts/012345-567890-ABCDEF`."
        }
      },
      "type": "object"
    },
    "GoogleCloudDocumentaiV1DocumentPageTableTableRow": {
      "id": "GoogleCloudDocumentaiV1DocumentPageTableTableRow",
      "description": "A row of table cells.",
      "type": "object",
      "properties": {
        "cells": {
          "description": "Cells that make up this row.",
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageTableTableCell"
          },
          "type": "array"
        }
      }
    },
    "GoogleCloudDocumentaiV1DocumentRevision": {
      "type": "object",
      "description": "Contains past or forward revisions of this document.",
      "id": "GoogleCloudDocumentaiV1DocumentRevision",
      "properties": {
        "humanReview": {
          "$ref": "GoogleCloudDocumentaiV1DocumentRevisionHumanReview",
          "description": "Human Review information of this revision."
        },
        "parent": {
          "items": {
            "type": "integer",
            "format": "int32"
          },
          "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.",
          "deprecated": true,
          "type": "array"
        },
        "parentIds": {
          "items": {
            "type": "string"
          },
          "type": "array",
          "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."
        },
        "processor": {
          "description": "If the annotation was made by processor identify the processor by its resource name.",
          "type": "string"
        },
        "createTime": {
          "format": "google-datetime",
          "description": "The time that the revision was created, internally generated by doc proto storage at the time of create.",
          "type": "string"
        },
        "id": {
          "description": "Id of the revision, internally generated by doc proto storage. Unique within the context of the document.",
          "type": "string"
        },
        "agent": {
          "type": "string",
          "description": "If the change was made by a person specify the name or id of that person."
        }
      }
    },
    "GoogleCloudContentwarehouseV1FloatTypeOptions": {
      "id": "GoogleCloudContentwarehouseV1FloatTypeOptions",
      "properties": {},
      "description": "Configurations for a float property.",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1ListLinkedSourcesRequest": {
      "description": "Response message for DocumentLinkService.ListLinkedSources.",
      "type": "object",
      "properties": {
        "requestMetadata": {
          "description": "The meta information collected about the document creator, used to enforce access control for the service.",
          "$ref": "GoogleCloudContentwarehouseV1RequestMetadata"
        },
        "pageSize": {
          "format": "int32",
          "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.",
          "type": "integer"
        },
        "pageToken": {
          "type": "string",
          "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."
        }
      },
      "id": "GoogleCloudContentwarehouseV1ListLinkedSourcesRequest"
    },
    "GoogleCloudContentwarehouseV1TextArray": {
      "properties": {
        "values": {
          "items": {
            "type": "string"
          },
          "description": "List of text values.",
          "type": "array"
        }
      },
      "description": "String/text values.",
      "id": "GoogleCloudContentwarehouseV1TextArray",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1ProcessWithDocAiPipeline": {
      "description": "The configuration of processing documents in Document Warehouse with DocAi processors pipeline.",
      "properties": {
        "processorInfo": {
          "description": "The CDW processor information.",
          "$ref": "GoogleCloudContentwarehouseV1ProcessorInfo"
        },
        "processorResultsFolderPath": {
          "description": "The Cloud Storage folder path used to store the raw results from processors. Format: `gs:///`.",
          "type": "string"
        },
        "exportFolderPath": {
          "description": "The Cloud Storage folder path used to store the exported documents before being sent to CDW. Format: `gs:///`.",
          "type": "string"
        },
        "documents": {
          "items": {
            "type": "string"
          },
          "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}."
        }
      },
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1ProcessWithDocAiPipeline"
    },
    "GoogleCloudContentwarehouseV1HistogramQueryResult": {
      "id": "GoogleCloudContentwarehouseV1HistogramQueryResult",
      "description": "Histogram result that matches HistogramQuery specified in searches.",
      "properties": {
        "histogramQuery": {
          "description": "Requested histogram expression.",
          "type": "string"
        },
        "histogram": {
          "additionalProperties": {
            "type": "string",
            "format": "int64"
          },
          "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.",
          "type": "object"
        }
      },
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1Rule": {
      "id": "GoogleCloudContentwarehouseV1Rule",
      "properties": {
        "ruleId": {
          "description": "ID of the rule. It has to be unique across all the examples. This is managed internally.",
          "type": "string"
        },
        "actions": {
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1Action"
          },
          "description": "List of actions that are executed when the rule is satisfied.",
          "type": "array"
        },
        "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"
          ],
          "description": "Identifies the trigger type for running the policy.",
          "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."
          ],
          "type": "string"
        },
        "description": {
          "description": "Short description of the rule and its context.",
          "type": "string"
        }
      },
      "type": "object",
      "description": "Represents the rule for a content warehouse trigger."
    },
    "GoogleTypeDateTime": {
      "properties": {
        "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"
        },
        "hours": {
          "format": "int32",
          "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.",
          "type": "integer"
        },
        "nanos": {
          "description": "Optional. Fractions of seconds in nanoseconds. Must be from 0 to 999,999,999, defaults to 0.",
          "type": "integer",
          "format": "int32"
        },
        "timeZone": {
          "$ref": "GoogleTypeTimeZone",
          "description": "Time zone."
        },
        "minutes": {
          "type": "integer",
          "description": "Optional. Minutes of hour of day. Must be from 0 to 59, defaults to 0.",
          "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"
        },
        "seconds": {
          "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.",
          "type": "integer",
          "format": "int32"
        },
        "year": {
          "type": "integer",
          "description": "Optional. Year of date. Must be from 1 to 9999, or 0 if specifying a datetime without a year.",
          "format": "int32"
        },
        "utcOffset": {
          "format": "google-duration",
          "type": "string",
          "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 }."
        }
      },
      "type": "object",
      "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.",
      "id": "GoogleTypeDateTime"
    },
    "GoogleCloudContentwarehouseV1RunPipelineMetadataIndividualDocumentStatus": {
      "description": "The status of processing a document.",
      "type": "object",
      "properties": {
        "documentId": {
          "type": "string",
          "description": "Document identifier of an existing document."
        },
        "status": {
          "$ref": "GoogleRpcStatus",
          "description": "The status processing the document."
        }
      },
      "id": "GoogleCloudContentwarehouseV1RunPipelineMetadataIndividualDocumentStatus"
    },
    "GoogleCloudDocumentaiV1DocumentShardInfo": {
      "type": "object",
      "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.",
      "id": "GoogleCloudDocumentaiV1DocumentShardInfo",
      "properties": {
        "shardIndex": {
          "type": "string",
          "description": "The 0-based index of this shard.",
          "format": "int64"
        },
        "textOffset": {
          "format": "int64",
          "type": "string",
          "description": "The index of the first character in Document.text in the overall document global text."
        },
        "shardCount": {
          "type": "string",
          "format": "int64",
          "description": "Total number of shards."
        }
      }
    },
    "GoogleCloudContentwarehouseV1Action": {
      "id": "GoogleCloudContentwarehouseV1Action",
      "type": "object",
      "description": "Represents the action triggered by Rule Engine when the rule is true.",
      "properties": {
        "accessControl": {
          "$ref": "GoogleCloudContentwarehouseV1AccessControlAction",
          "description": "Action triggering access control operations."
        },
        "publishToPubSub": {
          "$ref": "GoogleCloudContentwarehouseV1PublishAction",
          "description": "Action publish to Pub/Sub operation."
        },
        "addToFolder": {
          "$ref": "GoogleCloudContentwarehouseV1AddToFolderAction",
          "description": "Action triggering create document link operation."
        },
        "dataValidation": {
          "description": "Action triggering data validation operations.",
          "$ref": "GoogleCloudContentwarehouseV1DataValidationAction"
        },
        "removeFromFolderAction": {
          "$ref": "GoogleCloudContentwarehouseV1RemoveFromFolderAction",
          "description": "Action removing a document from a folder."
        },
        "deleteDocumentAction": {
          "$ref": "GoogleCloudContentwarehouseV1DeleteDocumentAction",
          "description": "Action deleting the document."
        },
        "actionId": {
          "type": "string",
          "description": "ID of the action. Managed internally."
        },
        "dataUpdate": {
          "$ref": "GoogleCloudContentwarehouseV1DataUpdateAction",
          "description": "Action triggering data update operations."
        }
      }
    },
    "GoogleCloudContentwarehouseV1AddToFolderAction": {
      "description": "Represents the action responsible for adding document under a folder.",
      "id": "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"
        }
      },
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1SynonymSet": {
      "id": "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": {
        "synonyms": {
          "type": "array",
          "description": "List of Synonyms for the context.",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1SynonymSetSynonym"
          }
        },
        "name": {
          "description": "The resource name of the SynonymSet This is mandatory for google.api.resource. Format: projects/{project_number}/locations/{location}/synonymSets/{context}.",
          "type": "string"
        },
        "context": {
          "type": "string",
          "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": "object"
    },
    "GoogleCloudContentwarehouseV1SynonymSetSynonym": {
      "id": "GoogleCloudContentwarehouseV1SynonymSetSynonym",
      "description": "Represents a list of words given by the customer All these words are synonyms of each other.",
      "type": "object",
      "properties": {
        "words": {
          "items": {
            "type": "string"
          },
          "type": "array",
          "description": "For example: sale, invoice, bill, order"
        }
      }
    },
    "GoogleCloudContentwarehouseV1SetAclRequest": {
      "type": "object",
      "description": "Request message for DocumentService.SetAcl.",
      "id": "GoogleCloudContentwarehouseV1SetAclRequest",
      "properties": {
        "requestMetadata": {
          "description": "The meta information collected about the end user, used to enforce access control for the service.",
          "$ref": "GoogleCloudContentwarehouseV1RequestMetadata"
        },
        "projectOwner": {
          "type": "boolean",
          "description": "For Set Project ACL only. Authorization check for end user will be ignored when project_owner=true."
        },
        "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"
        }
      }
    },
    "GoogleCloudContentwarehouseV1EnumValue": {
      "description": "Represents the string value of the enum field.",
      "properties": {
        "value": {
          "type": "string",
          "description": "String value of the enum field. This must match defined set of enums in document schema using EnumTypeOptions."
        }
      },
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1EnumValue"
    },
    "GoogleCloudDocumentaiV1DocumentPageSymbol": {
      "description": "A detected symbol.",
      "type": "object",
      "id": "GoogleCloudDocumentaiV1DocumentPageSymbol",
      "properties": {
        "detectedLanguages": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage"
          },
          "type": "array",
          "description": "A list of detected languages together with confidence."
        },
        "layout": {
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout",
          "description": "Layout for Symbol."
        }
      }
    },
    "GoogleCloudDocumentaiV1DocumentProvenanceParent": {
      "id": "GoogleCloudDocumentaiV1DocumentProvenanceParent",
      "description": "The parent element the current element is based on. Used for referencing/aligning, removal and replacement operations.",
      "type": "object",
      "properties": {
        "revision": {
          "description": "The index of the index into current revision's parent_ids list.",
          "format": "int32",
          "type": "integer"
        },
        "id": {
          "type": "integer",
          "description": "The id of the parent provenance.",
          "format": "int32",
          "deprecated": true
        },
        "index": {
          "format": "int32",
          "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."
        }
      }
    },
    "GoogleCloudContentwarehouseV1CreateDocumentRequest": {
      "type": "object",
      "description": "Request message for DocumentService.CreateDocument.",
      "properties": {
        "requestMetadata": {
          "$ref": "GoogleCloudContentwarehouseV1RequestMetadata",
          "description": "The meta information collected about the end user, used to enforce access control for the service."
        },
        "document": {
          "$ref": "GoogleCloudContentwarehouseV1Document",
          "description": "Required. The document to create."
        },
        "createMask": {
          "format": "google-fieldmask",
          "type": "string",
          "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."
        },
        "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"
        },
        "policy": {
          "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.",
          "$ref": "GoogleIamV1Policy"
        }
      },
      "id": "GoogleCloudContentwarehouseV1CreateDocumentRequest"
    },
    "GoogleCloudContentwarehouseV1ProcessorInfo": {
      "description": "The DocAI processor information.",
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1ProcessorInfo",
      "properties": {
        "processorName": {
          "type": "string",
          "description": "The processor resource name. Format is `projects/{project}/locations/{location}/processors/{processor}`, or `projects/{project}/locations/{location}/processors/{processor}/processorVersions/{processorVersion}`"
        },
        "documentType": {
          "description": "The processor will process the documents with this document type.",
          "type": "string"
        },
        "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"
        }
      }
    },
    "GoogleCloudContentwarehouseV1UpdateRuleSetRequest": {
      "description": "Request message for RuleSetService.UpdateRuleSet.",
      "id": "GoogleCloudContentwarehouseV1UpdateRuleSetRequest",
      "type": "object",
      "properties": {
        "ruleSet": {
          "$ref": "GoogleCloudContentwarehouseV1RuleSet",
          "description": "Required. The rule set to update."
        }
      }
    },
    "GoogleCloudDocumentaiV1DocumentStyleFontSize": {
      "id": "GoogleCloudDocumentaiV1DocumentStyleFontSize",
      "properties": {
        "unit": {
          "description": "Unit for the font size. Follows CSS naming (such as `in`, `px`, and `pt`).",
          "type": "string"
        },
        "size": {
          "type": "number",
          "format": "float",
          "description": "Font size for the text."
        }
      },
      "description": "Font size with unit.",
      "type": "object"
    },
    "GoogleTypePostalAddress": {
      "properties": {
        "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.)."
        },
        "administrativeArea": {
          "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.",
          "type": "string"
        },
        "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."
        },
        "organization": {
          "description": "Optional. The name of the organization at the address.",
          "type": "string"
        },
        "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.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "sortingCode": {
          "type": "string",
          "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)."
        },
        "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\"."
        },
        "addressLines": {
          "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"
          },
          "type": "array"
        },
        "locality": {
          "type": "string",
          "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."
        },
        "sublocality": {
          "description": "Optional. Sublocality of the address. For example, this can be neighborhoods, boroughs, districts.",
          "type": "string"
        },
        "revision": {
          "type": "integer",
          "format": "int32",
          "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."
        }
      },
      "type": "object",
      "id": "GoogleTypePostalAddress",
      "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"
    },
    "GoogleCloudContentwarehouseV1PublishAction": {
      "type": "object",
      "properties": {
        "topicId": {
          "type": "string",
          "description": "The topic id in the Pub/Sub service for which messages will be published to."
        },
        "messages": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "Messages to be published."
        }
      },
      "description": "Represents the action responsible for publishing messages to a Pub/Sub topic.",
      "id": "GoogleCloudContentwarehouseV1PublishAction"
    },
    "GoogleCloudDocumentaiV1DocumentPageImageQualityScores": {
      "id": "GoogleCloudDocumentaiV1DocumentPageImageQualityScores",
      "type": "object",
      "properties": {
        "detectedDefects": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageImageQualityScoresDetectedDefect"
          },
          "description": "A list of detected defects.",
          "type": "array"
        },
        "qualityScore": {
          "format": "float",
          "type": "number",
          "description": "The overall quality score. Range `[0, 1]` where `1` is perfect quality."
        }
      },
      "description": "Image quality scores for the page image."
    },
    "GoogleCloudContentwarehouseV1ExportToCdwPipeline": {
      "id": "GoogleCloudContentwarehouseV1ExportToCdwPipeline",
      "properties": {
        "docAiDataset": {
          "type": "string",
          "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"
        },
        "documents": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "The list of all the resource names of the documents to be processed. Format: projects/{project_number}/locations/{location}/documents/{document_id}."
        },
        "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",
          "format": "float",
          "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."
        }
      },
      "type": "object",
      "description": "The configuration of exporting documents from the Document Warehouse to CDW pipeline."
    },
    "GoogleCloudDocumentaiV1DocumentPageLine": {
      "type": "object",
      "id": "GoogleCloudDocumentaiV1DocumentPageLine",
      "properties": {
        "provenance": {
          "$ref": "GoogleCloudDocumentaiV1DocumentProvenance",
          "deprecated": true,
          "description": "The history of this annotation."
        },
        "layout": {
          "$ref": "GoogleCloudDocumentaiV1DocumentPageLayout",
          "description": "Layout for Line."
        },
        "detectedLanguages": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage"
          },
          "type": "array",
          "description": "A list of detected languages together with confidence."
        }
      },
      "description": "A collection of tokens that a human would perceive as a line. Does not cross column boundaries, can be horizontal, vertical, etc."
    },
    "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunkChunkPageSpan": {
      "description": "Represents where the chunk starts and ends in the document.",
      "properties": {
        "pageStart": {
          "format": "int32",
          "type": "integer",
          "description": "Page where chunk starts in the document."
        },
        "pageEnd": {
          "description": "Page where chunk ends in the document.",
          "format": "int32",
          "type": "integer"
        }
      },
      "type": "object",
      "id": "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunkChunkPageSpan"
    },
    "GoogleCloudContentwarehouseV1FloatArray": {
      "type": "object",
      "properties": {
        "values": {
          "items": {
            "type": "number",
            "format": "float"
          },
          "description": "List of float values.",
          "type": "array"
        }
      },
      "description": "Float values.",
      "id": "GoogleCloudContentwarehouseV1FloatArray"
    },
    "CloudAiPlatformTenantresourceInfraSpannerConfigCreateDatabaseOptions": {
      "id": "CloudAiPlatformTenantresourceInfraSpannerConfigCreateDatabaseOptions",
      "type": "object",
      "properties": {
        "cmekServiceName": {
          "description": "The service name for the CMEK encryption. For example, contentwarehouse.googleapis.com",
          "type": "string"
        },
        "cmekCloudResourceName": {
          "description": "The cloud resource name for the CMEK encryption. For example, projects//locations/",
          "type": "string"
        },
        "cmekCloudResourceType": {
          "description": "The cloud resource type for the CMEK encryption. For example, contentwarehouse.googleapis.com/Location",
          "type": "string"
        }
      },
      "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."
    },
    "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.",
      "type": "object",
      "properties": {
        "startTime": {
          "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": "string",
          "format": "google-datetime"
        },
        "endTime": {
          "format": "google-datetime",
          "type": "string",
          "description": "Optional. Exclusive end of the interval. If specified, a Timestamp matching this interval will have to be before the end."
        }
      },
      "id": "GoogleTypeInterval"
    },
    "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": {
          "type": "integer",
          "description": "Page where block ends in the document.",
          "format": "int32"
        }
      }
    },
    "GoogleCloudDocumentaiV1DocumentPageAnchor": {
      "id": "GoogleCloudDocumentaiV1DocumentPageAnchor",
      "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.",
      "properties": {
        "pageRefs": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentPageAnchorPageRef"
          },
          "type": "array",
          "description": "One or more references to visual page elements"
        }
      },
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1ListSynonymSetsResponse": {
      "description": "Response message for SynonymSetService.ListSynonymSets.",
      "id": "GoogleCloudContentwarehouseV1ListSynonymSetsResponse",
      "type": "object",
      "properties": {
        "synonymSets": {
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1SynonymSet"
          },
          "description": "The synonymSets from the specified parent.",
          "type": "array"
        },
        "nextPageToken": {
          "type": "string",
          "description": "A page token, received from a previous `ListSynonymSets` call. Provide this to retrieve the subsequent page."
        }
      }
    },
    "GoogleCloudDocumentaiV1Barcode": {
      "id": "GoogleCloudDocumentaiV1Barcode",
      "description": "Encodes the detailed information of a barcode.",
      "properties": {
        "valueFormat": {
          "type": "string",
          "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."
        },
        "rawValue": {
          "description": "Raw value encoded in the barcode. For example: `'MEBKM:TITLE:Google;URL:https://www.google.com;;'`.",
          "type": "string"
        },
        "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."
        }
      },
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1InitializeProjectRequest": {
      "properties": {
        "databaseType": {
          "enum": [
            "DB_UNKNOWN",
            "DB_INFRA_SPANNER",
            "DB_CLOUD_SQL_POSTGRES"
          ],
          "enumDescriptions": [
            "This value is required by protobuf best practices",
            "Internal Spanner",
            "Cloud Sql with a Postgres Sql instance"
          ],
          "type": "string",
          "enumDeprecated": [
            false,
            false,
            true
          ],
          "description": "Required. The type of database used to store customer data"
        },
        "kmsKey": {
          "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.",
          "type": "string"
        },
        "documentCreatorDefaultRole": {
          "type": "string",
          "enum": [
            "DOCUMENT_CREATOR_DEFAULT_ROLE_UNSPECIFIED",
            "DOCUMENT_ADMIN",
            "DOCUMENT_EDITOR",
            "DOCUMENT_VIEWER"
          ],
          "description": "Optional. The default role for the person who create a document.",
          "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."
          ]
        },
        "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."
          ],
          "description": "Required. The access control mode for accessing the customer data",
          "enum": [
            "ACL_MODE_UNKNOWN",
            "ACL_MODE_UNIVERSAL_ACCESS",
            "ACL_MODE_DOCUMENT_LEVEL_ACCESS_CONTROL_BYOID",
            "ACL_MODE_DOCUMENT_LEVEL_ACCESS_CONTROL_GCI"
          ],
          "type": "string"
        },
        "enableCalUserEmailLogging": {
          "description": "Optional. Whether to enable CAL user email logging.",
          "type": "boolean"
        }
      },
      "id": "GoogleCloudContentwarehouseV1InitializeProjectRequest",
      "type": "object",
      "description": "Request message for projectService.InitializeProject"
    },
    "GoogleCloudContentwarehouseV1IntegerTypeOptions": {
      "properties": {},
      "description": "Configurations for an integer property.",
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1IntegerTypeOptions"
    },
    "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.",
      "id": "GoogleCloudDocumentaiV1DocumentEntity",
      "properties": {
        "redacted": {
          "description": "Optional. Whether the entity will be redacted for de-identification purposes.",
          "type": "boolean"
        },
        "normalizedValue": {
          "$ref": "GoogleCloudDocumentaiV1DocumentEntityNormalizedValue",
          "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."
        },
        "textAnchor": {
          "description": "Optional. Provenance of the entity. Text anchor indexing into the Document.text.",
          "$ref": "GoogleCloudDocumentaiV1DocumentTextAnchor"
        },
        "provenance": {
          "description": "Optional. The history of this annotation.",
          "$ref": "GoogleCloudDocumentaiV1DocumentProvenance"
        },
        "properties": {
          "items": {
            "$ref": "GoogleCloudDocumentaiV1DocumentEntity"
          },
          "type": "array",
          "description": "Optional. Entities can be nested to form a hierarchical data structure representing the content in the document."
        },
        "id": {
          "type": "string",
          "description": "Optional. Canonical id. This will be a unique value in the entity list for this document."
        },
        "pageAnchor": {
          "$ref": "GoogleCloudDocumentaiV1DocumentPageAnchor",
          "description": "Optional. Represents the provenance of this entity wrt. the location on the page where it was found."
        },
        "mentionText": {
          "type": "string",
          "description": "Optional. Text value of the entity e.g. `1600 Amphitheatre Pkwy`."
        },
        "type": {
          "description": "Required. Entity type from a schema e.g. `Address`.",
          "type": "string"
        },
        "mentionId": {
          "description": "Optional. Deprecated. Use `id` field instead.",
          "type": "string"
        },
        "confidence": {
          "format": "float",
          "description": "Optional. Confidence of detected Schema entity. Range `[0, 1]`.",
          "type": "number"
        }
      },
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1InvalidRule": {
      "type": "object",
      "properties": {
        "rule": {
          "description": "Triggered rule.",
          "$ref": "GoogleCloudContentwarehouseV1Rule"
        },
        "error": {
          "description": "Validation error on a parsed expression.",
          "type": "string"
        }
      },
      "description": "A triggered rule that failed the validation check(s) after parsing.",
      "id": "GoogleCloudContentwarehouseV1InvalidRule"
    },
    "GoogleCloudDocumentaiV1Vertex": {
      "type": "object",
      "properties": {
        "x": {
          "description": "X coordinate.",
          "type": "integer",
          "format": "int32"
        },
        "y": {
          "format": "int32",
          "type": "integer",
          "description": "Y coordinate (starts from the top of the image)."
        }
      },
      "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."
    },
    "GoogleCloudContentwarehouseV1DeleteDocumentAction": {
      "description": "Represents the action responsible for deleting the document.",
      "properties": {
        "enableHardDelete": {
          "description": "Boolean field to select between hard vs soft delete options. Set 'true' for 'hard delete' and 'false' for 'soft delete'.",
          "type": "boolean"
        }
      },
      "id": "GoogleCloudContentwarehouseV1DeleteDocumentAction",
      "type": "object"
    },
    "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTableCell": {
      "properties": {
        "rowSpan": {
          "description": "How many rows this cell spans.",
          "type": "integer",
          "format": "int32"
        },
        "colSpan": {
          "type": "integer",
          "format": "int32",
          "description": "How many columns 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"
        }
      },
      "description": "Represents a cell in a table row.",
      "type": "object",
      "id": "GoogleCloudDocumentaiV1DocumentDocumentLayoutDocumentLayoutBlockLayoutTableCell"
    },
    "GoogleCloudContentwarehouseV1DocumentSchema": {
      "type": "object",
      "description": "A document schema used to define document structure.",
      "properties": {
        "propertyDefinitions": {
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1PropertyDefinition"
          },
          "type": "array",
          "description": "Document details."
        },
        "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"
        },
        "displayName": {
          "type": "string",
          "description": "Required. Name of the schema given by the user. Must be unique per project."
        },
        "description": {
          "description": "Schema description.",
          "type": "string"
        },
        "createTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "Output only. The time when the document schema is created.",
          "readOnly": true
        },
        "documentIsFolder": {
          "type": "boolean",
          "description": "Document Type, true refers the document is a folder, otherwise it is a typical document."
        },
        "updateTime": {
          "format": "google-datetime",
          "readOnly": true,
          "type": "string",
          "description": "Output only. The time when the document schema is last updated."
        }
      },
      "id": "GoogleCloudContentwarehouseV1DocumentSchema"
    },
    "GoogleCloudContentwarehouseV1MapProperty": {
      "type": "object",
      "description": "Map property value. Represents a structured entries of key value pairs, consisting of field names which map to dynamically typed values.",
      "properties": {
        "fields": {
          "description": "Unordered map of dynamically typed values.",
          "additionalProperties": {
            "$ref": "GoogleCloudContentwarehouseV1Value"
          },
          "type": "object"
        }
      },
      "id": "GoogleCloudContentwarehouseV1MapProperty"
    },
    "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunkChunkPageFooter": {
      "id": "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunkChunkPageFooter",
      "description": "Represents the page footer associated with the chunk.",
      "type": "object",
      "properties": {
        "text": {
          "description": "Footer in text format.",
          "type": "string"
        },
        "pageSpan": {
          "$ref": "GoogleCloudDocumentaiV1DocumentChunkedDocumentChunkChunkPageSpan",
          "description": "Page span of the footer."
        }
      }
    },
    "GoogleCloudContentwarehouseV1RuleEvaluatorOutput": {
      "description": "Represents the output of the Rule Evaluator.",
      "properties": {
        "invalidRules": {
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1InvalidRule"
          },
          "type": "array",
          "description": "A subset of triggered rules that failed the validation check(s) after parsing."
        },
        "triggeredRules": {
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1Rule"
          },
          "type": "array",
          "description": "List of rules fetched from database for the given request trigger type."
        },
        "matchedRules": {
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1Rule"
          },
          "type": "array",
          "description": "A subset of triggered rules that are evaluated true for a given request."
        }
      },
      "id": "GoogleCloudContentwarehouseV1RuleEvaluatorOutput",
      "type": "object"
    },
    "CloudAiPlatformTenantresourceTenantProjectConfig": {
      "type": "object",
      "properties": {
        "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}`."
        },
        "services": {
          "items": {
            "type": "string"
          },
          "type": "array",
          "description": "Input/Output [Required]. The API services that are enabled on the tenant project during creation."
        },
        "policyBindings": {
          "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.",
          "items": {
            "$ref": "GoogleApiServiceconsumermanagementV1PolicyBinding"
          },
          "type": "array"
        },
        "billingConfig": {
          "$ref": "GoogleApiServiceconsumermanagementV1BillingConfig",
          "description": "Input/Output [Required]. The billing account properties to create the tenant project."
        }
      },
      "description": "The identity to configure a tenant project.",
      "id": "CloudAiPlatformTenantresourceTenantProjectConfig"
    },
    "GoogleCloudContentwarehouseV1RunPipelineMetadata": {
      "type": "object",
      "description": "Metadata message of RunPipeline method.",
      "properties": {
        "individualDocumentStatuses": {
          "type": "array",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1RunPipelineMetadataIndividualDocumentStatus"
          },
          "description": "The list of response details of each document."
        },
        "gcsIngestPipelineMetadata": {
          "description": "The pipeline metadata for GcsIngest pipeline.",
          "$ref": "GoogleCloudContentwarehouseV1RunPipelineMetadataGcsIngestPipelineMetadata"
        },
        "exportToCdwPipelineMetadata": {
          "$ref": "GoogleCloudContentwarehouseV1RunPipelineMetadataExportToCdwPipelineMetadata",
          "description": "The pipeline metadata for Export-to-CDW pipeline."
        },
        "processWithDocAiPipelineMetadata": {
          "description": "The pipeline metadata for Process-with-DocAi pipeline.",
          "$ref": "GoogleCloudContentwarehouseV1RunPipelineMetadataProcessWithDocAiPipelineMetadata"
        },
        "userInfo": {
          "$ref": "GoogleCloudContentwarehouseV1UserInfo",
          "description": "User unique identification and groups information."
        },
        "failedFileCount": {
          "type": "integer",
          "format": "int32",
          "description": "Number of files that have failed at some point in the pipeline."
        },
        "totalFileCount": {
          "description": "Number of files that were processed by the pipeline.",
          "format": "int32",
          "type": "integer"
        }
      },
      "id": "GoogleCloudContentwarehouseV1RunPipelineMetadata"
    },
    "GoogleCloudContentwarehouseV1GetDocumentRequest": {
      "id": "GoogleCloudContentwarehouseV1GetDocumentRequest",
      "description": "Request message for DocumentService.GetDocument.",
      "properties": {
        "requestMetadata": {
          "$ref": "GoogleCloudContentwarehouseV1RequestMetadata",
          "description": "The meta information collected about the end user, used to enforce access control for the service."
        }
      },
      "type": "object"
    },
    "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage": {
      "description": "Detected language for a structural component.",
      "properties": {
        "confidence": {
          "description": "Confidence of detected language. Range `[0, 1]`.",
          "type": "number",
          "format": "float"
        },
        "languageCode": {
          "description": "The [BCP-47 language code](https://www.unicode.org/reports/tr35/#Unicode_locale_identifier), such as `en-US` or `sr-Latn`.",
          "type": "string"
        }
      },
      "type": "object",
      "id": "GoogleCloudDocumentaiV1DocumentPageDetectedLanguage"
    },
    "GoogleCloudContentwarehouseV1RuleActionsPair": {
      "id": "GoogleCloudContentwarehouseV1RuleActionsPair",
      "properties": {
        "rule": {
          "description": "Represents the rule.",
          "$ref": "GoogleCloudContentwarehouseV1Rule"
        },
        "actionOutputs": {
          "description": "Outputs of executing the actions associated with the above rule.",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1ActionOutput"
          },
          "type": "array"
        }
      },
      "description": "Represents a rule and outputs of associated actions.",
      "type": "object"
    },
    "GoogleIamV1Policy": {
      "type": "object",
      "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/).",
      "id": "GoogleIamV1Policy",
      "properties": {
        "auditConfigs": {
          "type": "array",
          "items": {
            "$ref": "GoogleIamV1AuditConfig"
          },
          "description": "Specifies cloud audit logging configuration for this policy."
        },
        "version": {
          "type": "integer",
          "format": "int32",
          "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)."
        },
        "bindings": {
          "type": "array",
          "items": {
            "$ref": "GoogleIamV1Binding"
          },
          "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`."
        },
        "etag": {
          "format": "byte",
          "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."
        }
      }
    },
    "GoogleCloudContentwarehouseV1DeleteDocumentRequest": {
      "properties": {
        "requestMetadata": {
          "description": "The meta information collected about the end user, used to enforce access control for the service.",
          "$ref": "GoogleCloudContentwarehouseV1RequestMetadata"
        }
      },
      "description": "Request message for DocumentService.DeleteDocument.",
      "id": "GoogleCloudContentwarehouseV1DeleteDocumentRequest",
      "type": "object"
    },
    "GoogleCloudContentwarehouseV1CustomWeightsMetadata": {
      "properties": {
        "weightedSchemaProperties": {
          "description": "List of schema and property name. Allows a maximum of 10 schemas to be specified for relevance boosting.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1WeightedSchemaProperty"
          }
        }
      },
      "description": "To support the custom weighting across document schemas.",
      "type": "object",
      "id": "GoogleCloudContentwarehouseV1CustomWeightsMetadata"
    },
    "GoogleCloudContentwarehouseV1beta1UpdateDocumentMetadata": {
      "type": "object",
      "properties": {},
      "id": "GoogleCloudContentwarehouseV1beta1UpdateDocumentMetadata",
      "description": "Metadata object for UpdateDocument request (currently empty)."
    },
    "GoogleTypeTimeZone": {
      "properties": {
        "version": {
          "type": "string",
          "description": "Optional. IANA Time Zone Database version number. For example \"2019a\"."
        },
        "id": {
          "type": "string",
          "description": "IANA Time Zone Database time zone. For example \"America/New_York\"."
        }
      },
      "description": "Represents a time zone from the [IANA Time Zone Database](https://www.iana.org/time-zones).",
      "type": "object",
      "id": "GoogleTypeTimeZone"
    },
    "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": {
        "title": {
          "type": "string",
          "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."
        },
        "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."
        },
        "expression": {
          "type": "string",
          "description": "Textual representation of an expression in Common Expression Language syntax."
        },
        "location": {
          "type": "string",
          "description": "Optional. String indicating the location of the expression for error reporting, e.g. a file name and a position in the file."
        }
      }
    },
    "GoogleCloudContentwarehouseV1ListLinkedSourcesResponse": {
      "id": "GoogleCloudContentwarehouseV1ListLinkedSourcesResponse",
      "type": "object",
      "description": "Response message for DocumentLinkService.ListLinkedSources.",
      "properties": {
        "documentLinks": {
          "description": "Source document-links.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudContentwarehouseV1DocumentLink"
          }
        },
        "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"
        }
      }
    },
    "GoogleCloudContentwarehouseV1ProjectStatus": {
      "description": "Status of a project, including the project state, dbType, aclMode and etc.",
      "properties": {
        "qaEnabled": {
          "description": "If the qa is enabled on this project.",
          "type": "boolean"
        },
        "accessControlMode": {
          "type": "string",
          "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.",
          "enum": [
            "ACL_MODE_UNKNOWN",
            "ACL_MODE_UNIVERSAL_ACCESS",
            "ACL_MODE_DOCUMENT_LEVEL_ACCESS_CONTROL_BYOID",
            "ACL_MODE_DOCUMENT_LEVEL_ACCESS_CONTROL_GCI"
          ]
        },
        "documentCreatorDefaultRole": {
          "type": "string",
          "description": "The default role for the person who create a document."
        },
        "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"
          ],
          "type": "string",
          "description": "State of the project.",
          "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."
          ]
        },
        "databaseType": {
          "enumDescriptions": [
            "This value is required by protobuf best practices",
            "Internal Spanner",
            "Cloud Sql with a Postgres Sql instance"
          ],
          "type": "string",
          "enumDeprecated": [
            false,
            false,
            true
          ],
          "description": "Database type.",
          "enum": [
            "DB_UNKNOWN",
            "DB_INFRA_SPANNER",
            "DB_CLOUD_SQL_POSTGRES"
          ]
        }
      },
      "id": "GoogleCloudContentwarehouseV1ProjectStatus",
      "type": "object"
    }
  },
  "discoveryVersion": "v1",
  "documentationLink": "https://cloud.google.com/document-warehouse",
  "baseUrl": "https://contentwarehouse.googleapis.com/",
  "parameters": {
    "fields": {
      "description": "Selector specifying which fields to include in a partial response.",
      "location": "query",
      "type": "string"
    },
    "prettyPrint": {
      "type": "boolean",
      "location": "query",
      "description": "Returns response with indentations and line breaks.",
      "default": "true"
    },
    "uploadType": {
      "location": "query",
      "description": "Legacy upload protocol for media (e.g. \"media\", \"multipart\").",
      "type": "string"
    },
    "quotaUser": {
      "location": "query",
      "type": "string",
      "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."
    },
    "upload_protocol": {
      "location": "query",
      "type": "string",
      "description": "Upload protocol for media (e.g. \"raw\", \"multipart\")."
    },
    "oauth_token": {
      "description": "OAuth 2.0 token for the current user.",
      "location": "query",
      "type": "string"
    },
    "alt": {
      "type": "string",
      "enum": [
        "json",
        "media",
        "proto"
      ],
      "description": "Data format for response.",
      "enumDescriptions": [
        "Responses with Content-Type of application/json",
        "Media download with context-dependent Content-Type",
        "Responses with Content-Type of application/x-protobuf"
      ],
      "location": "query",
      "default": "json"
    },
    "access_token": {
      "description": "OAuth access token.",
      "location": "query",
      "type": "string"
    },
    "key": {
      "type": "string",
      "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.",
      "location": "query"
    },
    "$.xgafv": {
      "type": "string",
      "description": "V1 error format.",
      "enum": [
        "1",
        "2"
      ],
      "enumDescriptions": [
        "v1 error format",
        "v2 error format"
      ],
      "location": "query"
    },
    "callback": {
      "type": "string",
      "description": "JSONP",
      "location": "query"
    }
  },
  "rootUrl": "https://contentwarehouse.googleapis.com/",
  "canonicalName": "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."
        }
      }
    }
  },
  "protocol": "rest",
  "name": "contentwarehouse",
  "ownerName": "Google",
  "version": "v1",
  "resources": {
    "projects": {
      "methods": {
        "fetchAcl": {
          "response": {
            "$ref": "GoogleCloudContentwarehouseV1FetchAclResponse"
          },
          "path": "v1/{+resource}:fetchAcl",
          "id": "contentwarehouse.projects.fetchAcl",
          "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.",
          "flatPath": "v1/projects/{projectsId}:fetchAcl",
          "parameters": {
            "resource": {
              "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,
              "pattern": "^projects/[^/]+$",
              "location": "path",
              "type": "string"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/cloud-platform"
          ],
          "parameterOrder": [
            "resource"
          ],
          "request": {
            "$ref": "GoogleCloudContentwarehouseV1FetchAclRequest"
          },
          "httpMethod": "POST"
        },
        "setAcl": {
          "scopes": [
            "https://www.googleapis.com/auth/cloud-platform"
          ],
          "parameterOrder": [
            "resource"
          ],
          "description": "Sets the access control policy for a resource. Replaces any existing policy.",
          "httpMethod": "POST",
          "response": {
            "$ref": "GoogleCloudContentwarehouseV1SetAclResponse"
          },
          "path": "v1/{+resource}:setAcl",
          "flatPath": "v1/projects/{projectsId}:setAcl",
          "id": "contentwarehouse.projects.setAcl",
          "parameters": {
            "resource": {
              "type": "string",
              "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,
              "location": "path",
              "pattern": "^projects/[^/]+$"
            }
          },
          "request": {
            "$ref": "GoogleCloudContentwarehouseV1SetAclRequest"
          }
        }
      },
      "resources": {
        "locations": {
          "resources": {
            "ruleSets": {
              "methods": {
                "delete": {
                  "response": {
                    "$ref": "GoogleProtobufEmpty"
                  },
                  "path": "v1/{+name}",
                  "parameters": {
                    "name": {
                      "required": true,
                      "type": "string",
                      "pattern": "^projects/[^/]+/locations/[^/]+/ruleSets/[^/]+$",
                      "location": "path",
                      "description": "Required. The name of the rule set to delete. Format: projects/{project_number}/locations/{location}/ruleSets/{rule_set_id}."
                    }
                  },
                  "description": "Deletes a ruleset. Returns NOT_FOUND if the document does not exist.",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/ruleSets/{ruleSetsId}",
                  "id": "contentwarehouse.projects.locations.ruleSets.delete",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameterOrder": [
                    "name"
                  ],
                  "httpMethod": "DELETE"
                },
                "patch": {
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "id": "contentwarehouse.projects.locations.ruleSets.patch",
                  "path": "v1/{+name}",
                  "parameterOrder": [
                    "name"
                  ],
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1RuleSet"
                  },
                  "parameters": {
                    "name": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "description": "Required. The name of the rule set to update. Format: projects/{project_number}/locations/{location}/ruleSets/{rule_set_id}.",
                      "pattern": "^projects/[^/]+/locations/[^/]+/ruleSets/[^/]+$"
                    }
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/ruleSets/{ruleSetsId}",
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1UpdateRuleSetRequest"
                  },
                  "httpMethod": "PATCH",
                  "description": "Updates a ruleset. Returns INVALID_ARGUMENT if the name of the ruleset is non-empty and does not equal the existing name."
                },
                "create": {
                  "id": "contentwarehouse.projects.locations.ruleSets.create",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/ruleSets",
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1RuleSet"
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameterOrder": [
                    "parent"
                  ],
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1RuleSet"
                  },
                  "path": "v1/{+parent}/ruleSets",
                  "description": "Creates a ruleset.",
                  "parameters": {
                    "parent": {
                      "location": "path",
                      "type": "string",
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "required": true,
                      "description": "Required. The parent name. Format: projects/{project_number}/locations/{location}."
                    }
                  },
                  "httpMethod": "POST"
                },
                "list": {
                  "description": "Lists rulesets.",
                  "parameters": {
                    "parent": {
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "type": "string",
                      "location": "path",
                      "description": "Required. The parent, which owns this collection of document. Format: projects/{project_number}/locations/{location}.",
                      "required": true
                    },
                    "pageToken": {
                      "type": "string",
                      "location": "query",
                      "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."
                    },
                    "pageSize": {
                      "format": "int32",
                      "type": "integer",
                      "location": "query",
                      "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."
                    }
                  },
                  "httpMethod": "GET",
                  "parameterOrder": [
                    "parent"
                  ],
                  "id": "contentwarehouse.projects.locations.ruleSets.list",
                  "path": "v1/{+parent}/ruleSets",
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1ListRuleSetsResponse"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/ruleSets",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ]
                },
                "get": {
                  "parameterOrder": [
                    "name"
                  ],
                  "path": "v1/{+name}",
                  "httpMethod": "GET",
                  "id": "contentwarehouse.projects.locations.ruleSets.get",
                  "description": "Gets a ruleset. Returns NOT_FOUND if the ruleset does not exist.",
                  "parameters": {
                    "name": {
                      "pattern": "^projects/[^/]+/locations/[^/]+/ruleSets/[^/]+$",
                      "description": "Required. The name of the rule set to retrieve. Format: projects/{project_number}/locations/{location}/ruleSets/{rule_set_id}.",
                      "required": true,
                      "type": "string",
                      "location": "path"
                    }
                  },
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1RuleSet"
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/ruleSets/{ruleSetsId}"
                }
              }
            },
            "synonymSets": {
              "methods": {
                "list": {
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1ListSynonymSetsResponse"
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "id": "contentwarehouse.projects.locations.synonymSets.list",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/synonymSets",
                  "parameters": {
                    "pageToken": {
                      "location": "query",
                      "type": "string",
                      "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."
                    },
                    "pageSize": {
                      "location": "query",
                      "type": "integer",
                      "format": "int32",
                      "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."
                    },
                    "parent": {
                      "location": "path",
                      "required": true,
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "description": "Required. The parent name. Format: projects/{project_number}/locations/{location}.",
                      "type": "string"
                    }
                  },
                  "path": "v1/{+parent}/synonymSets",
                  "description": "Returns all SynonymSets (for all contexts) for the specified location.",
                  "httpMethod": "GET",
                  "parameterOrder": [
                    "parent"
                  ]
                },
                "create": {
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameterOrder": [
                    "parent"
                  ],
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1SynonymSet"
                  },
                  "parameters": {
                    "parent": {
                      "type": "string",
                      "description": "Required. The parent name. Format: projects/{project_number}/locations/{location}.",
                      "location": "path",
                      "required": true,
                      "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.",
                  "path": "v1/{+parent}/synonymSets",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/synonymSets",
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1SynonymSet"
                  },
                  "httpMethod": "POST"
                },
                "patch": {
                  "path": "v1/{+name}",
                  "id": "contentwarehouse.projects.locations.synonymSets.patch",
                  "parameterOrder": [
                    "name"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1SynonymSet"
                  },
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1SynonymSet"
                  },
                  "parameters": {
                    "name": {
                      "pattern": "^projects/[^/]+/locations/[^/]+/synonymSets/[^/]+$",
                      "description": "Required. The name of the synonymSet to update Format: projects/{project_number}/locations/{location}/synonymSets/{context}.",
                      "location": "path",
                      "required": true,
                      "type": "string"
                    }
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/synonymSets/{synonymSetsId}",
                  "httpMethod": "PATCH",
                  "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."
                },
                "delete": {
                  "id": "contentwarehouse.projects.locations.synonymSets.delete",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "path": "v1/{+name}",
                  "parameters": {
                    "name": {
                      "pattern": "^projects/[^/]+/locations/[^/]+/synonymSets/[^/]+$",
                      "required": true,
                      "description": "Required. The name of the synonymSet to delete Format: projects/{project_number}/locations/{location}/synonymSets/{context}.",
                      "type": "string",
                      "location": "path"
                    }
                  },
                  "description": "Deletes a SynonymSet for a given context. Throws a NOT_FOUND exception if the SynonymSet is not found.",
                  "parameterOrder": [
                    "name"
                  ],
                  "response": {
                    "$ref": "GoogleProtobufEmpty"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/synonymSets/{synonymSetsId}",
                  "httpMethod": "DELETE"
                },
                "get": {
                  "parameters": {
                    "name": {
                      "location": "path",
                      "pattern": "^projects/[^/]+/locations/[^/]+/synonymSets/[^/]+$",
                      "description": "Required. The name of the synonymSet to retrieve Format: projects/{project_number}/locations/{location}/synonymSets/{context}.",
                      "type": "string",
                      "required": true
                    }
                  },
                  "description": "Gets a SynonymSet for a particular context. Throws a NOT_FOUND exception if the Synonymset does not exist",
                  "httpMethod": "GET",
                  "parameterOrder": [
                    "name"
                  ],
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1SynonymSet"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/synonymSets/{synonymSetsId}",
                  "id": "contentwarehouse.projects.locations.synonymSets.get",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "path": "v1/{+name}"
                }
              }
            },
            "documents": {
              "methods": {
                "linkedSources": {
                  "id": "contentwarehouse.projects.locations.documents.linkedSources",
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1ListLinkedSourcesRequest"
                  },
                  "path": "v1/{+parent}/linkedSources",
                  "parameterOrder": [
                    "parent"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/{documentsId}/linkedSources",
                  "httpMethod": "POST",
                  "description": "Return all source document-links from the document.",
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1ListLinkedSourcesResponse"
                  },
                  "parameters": {
                    "parent": {
                      "required": true,
                      "description": "Required. The name of the document, for which all source links are returned. Format: projects/{project_number}/locations/{location}/documents/{source_document_id}.",
                      "type": "string",
                      "pattern": "^projects/[^/]+/locations/[^/]+/documents/[^/]+$",
                      "location": "path"
                    }
                  }
                },
                "fetchAcl": {
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1FetchAclRequest"
                  },
                  "httpMethod": "POST",
                  "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.",
                  "parameterOrder": [
                    "resource"
                  ],
                  "parameters": {
                    "resource": {
                      "location": "path",
                      "required": true,
                      "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}.",
                      "pattern": "^projects/[^/]+/locations/[^/]+/documents/[^/]+$",
                      "type": "string"
                    }
                  },
                  "id": "contentwarehouse.projects.locations.documents.fetchAcl",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/{documentsId}:fetchAcl",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "path": "v1/{+resource}:fetchAcl",
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1FetchAclResponse"
                  }
                },
                "get": {
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1GetDocumentRequest"
                  },
                  "path": "v1/{+name}:get",
                  "httpMethod": "POST",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1Document"
                  },
                  "description": "Gets a document. Returns NOT_FOUND if the document does not exist.",
                  "id": "contentwarehouse.projects.locations.documents.get",
                  "parameters": {
                    "name": {
                      "location": "path",
                      "type": "string",
                      "required": true,
                      "pattern": "^projects/[^/]+/locations/[^/]+/documents/[^/]+$",
                      "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}."
                    }
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/{documentsId}:get",
                  "parameterOrder": [
                    "name"
                  ]
                },
                "search": {
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents:search",
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1SearchDocumentsResponse"
                  },
                  "parameterOrder": [
                    "parent"
                  ],
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1SearchDocumentsRequest"
                  },
                  "description": "Searches for documents using provided SearchDocumentsRequest. This call only returns documents that the caller has permission to search against.",
                  "path": "v1/{+parent}/documents:search",
                  "httpMethod": "POST",
                  "id": "contentwarehouse.projects.locations.documents.search",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameters": {
                    "parent": {
                      "type": "string",
                      "description": "Required. The parent, which owns this collection of documents. Format: projects/{project_number}/locations/{location}.",
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "required": true,
                      "location": "path"
                    }
                  }
                },
                "lock": {
                  "id": "contentwarehouse.projects.locations.documents.lock",
                  "parameters": {
                    "name": {
                      "location": "path",
                      "pattern": "^projects/[^/]+/locations/[^/]+/documents/[^/]+$",
                      "required": true,
                      "type": "string",
                      "description": "Required. The name of the document to lock. Format: projects/{project_number}/locations/{location}/documents/{document}."
                    }
                  },
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Lock the document so the document cannot be updated by other users.",
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1LockDocumentRequest"
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "httpMethod": "POST",
                  "path": "v1/{+name}:lock",
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1Document"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/{documentsId}:lock"
                },
                "patch": {
                  "parameterOrder": [
                    "name"
                  ],
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1UpdateDocumentRequest"
                  },
                  "httpMethod": "PATCH",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1UpdateDocumentResponse"
                  },
                  "id": "contentwarehouse.projects.locations.documents.patch",
                  "path": "v1/{+name}",
                  "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": {
                      "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,
                      "pattern": "^projects/[^/]+/locations/[^/]+/documents/[^/]+$",
                      "type": "string"
                    }
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/{documentsId}"
                },
                "delete": {
                  "parameterOrder": [
                    "name"
                  ],
                  "response": {
                    "$ref": "GoogleProtobufEmpty"
                  },
                  "httpMethod": "POST",
                  "id": "contentwarehouse.projects.locations.documents.delete",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/{documentsId}:delete",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "path": "v1/{+name}:delete",
                  "description": "Deletes a document. Returns NOT_FOUND if the document does not exist.",
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1DeleteDocumentRequest"
                  },
                  "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}.",
                      "type": "string",
                      "location": "path",
                      "pattern": "^projects/[^/]+/locations/[^/]+/documents/[^/]+$",
                      "required": true
                    }
                  }
                },
                "create": {
                  "parameterOrder": [
                    "parent"
                  ],
                  "httpMethod": "POST",
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1CreateDocumentRequest"
                  },
                  "description": "Creates a document.",
                  "id": "contentwarehouse.projects.locations.documents.create",
                  "parameters": {
                    "parent": {
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "description": "Required. The parent name. Format: projects/{project_number}/locations/{location}.",
                      "type": "string",
                      "required": true,
                      "location": "path"
                    }
                  },
                  "path": "v1/{+parent}/documents",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1CreateDocumentResponse"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents"
                },
                "setAcl": {
                  "description": "Sets the access control policy for a resource. Replaces any existing policy.",
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1SetAclRequest"
                  },
                  "parameters": {
                    "resource": {
                      "pattern": "^projects/[^/]+/locations/[^/]+/documents/[^/]+$",
                      "type": "string",
                      "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}.",
                      "location": "path",
                      "required": true
                    }
                  },
                  "parameterOrder": [
                    "resource"
                  ],
                  "path": "v1/{+resource}:setAcl",
                  "httpMethod": "POST",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/{documentsId}:setAcl",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1SetAclResponse"
                  },
                  "id": "contentwarehouse.projects.locations.documents.setAcl"
                },
                "linkedTargets": {
                  "path": "v1/{+parent}/linkedTargets",
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1ListLinkedTargetsRequest"
                  },
                  "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",
                      "location": "path",
                      "pattern": "^projects/[^/]+/locations/[^/]+/documents/[^/]+$"
                    }
                  },
                  "id": "contentwarehouse.projects.locations.documents.linkedTargets",
                  "parameterOrder": [
                    "parent"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/{documentsId}/linkedTargets",
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1ListLinkedTargetsResponse"
                  },
                  "description": "Return all target document-links from the document.",
                  "httpMethod": "POST"
                }
              },
              "resources": {
                "documentLinks": {
                  "methods": {
                    "create": {
                      "response": {
                        "$ref": "GoogleCloudContentwarehouseV1DocumentLink"
                      },
                      "request": {
                        "$ref": "GoogleCloudContentwarehouseV1CreateDocumentLinkRequest"
                      },
                      "description": "Create a link between a source document and a target document.",
                      "parameters": {
                        "parent": {
                          "pattern": "^projects/[^/]+/locations/[^/]+/documents/[^/]+$",
                          "location": "path",
                          "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}.",
                          "required": true,
                          "type": "string"
                        }
                      },
                      "id": "contentwarehouse.projects.locations.documents.documentLinks.create",
                      "path": "v1/{+parent}/documentLinks",
                      "httpMethod": "POST",
                      "parameterOrder": [
                        "parent"
                      ],
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/{documentsId}/documentLinks"
                    },
                    "delete": {
                      "id": "contentwarehouse.projects.locations.documents.documentLinks.delete",
                      "description": "Remove the link between the source and target documents.",
                      "response": {
                        "$ref": "GoogleProtobufEmpty"
                      },
                      "path": "v1/{+name}:delete",
                      "parameters": {
                        "name": {
                          "required": true,
                          "pattern": "^projects/[^/]+/locations/[^/]+/documents/[^/]+/documentLinks/[^/]+$",
                          "location": "path",
                          "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}.",
                          "type": "string"
                        }
                      },
                      "request": {
                        "$ref": "GoogleCloudContentwarehouseV1DeleteDocumentLinkRequest"
                      },
                      "parameterOrder": [
                        "name"
                      ],
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/{documentsId}/documentLinks/{documentLinksId}:delete",
                      "httpMethod": "POST",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ]
                    }
                  }
                },
                "referenceId": {
                  "methods": {
                    "delete": {
                      "request": {
                        "$ref": "GoogleCloudContentwarehouseV1DeleteDocumentRequest"
                      },
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "httpMethod": "POST",
                      "description": "Deletes a document. Returns NOT_FOUND if the document does not exist.",
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/referenceId/{referenceIdId}:delete",
                      "parameters": {
                        "name": {
                          "type": "string",
                          "pattern": "^projects/[^/]+/locations/[^/]+/documents/referenceId/[^/]+$",
                          "location": "path",
                          "required": true,
                          "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}."
                        }
                      },
                      "response": {
                        "$ref": "GoogleProtobufEmpty"
                      },
                      "parameterOrder": [
                        "name"
                      ],
                      "id": "contentwarehouse.projects.locations.documents.referenceId.delete",
                      "path": "v1/{+name}:delete"
                    },
                    "patch": {
                      "path": "v1/{+name}",
                      "httpMethod": "PATCH",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "parameterOrder": [
                        "name"
                      ],
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/referenceId/{referenceIdId}",
                      "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": {
                          "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}.",
                          "type": "string",
                          "pattern": "^projects/[^/]+/locations/[^/]+/documents/referenceId/[^/]+$",
                          "required": true,
                          "location": "path"
                        }
                      },
                      "request": {
                        "$ref": "GoogleCloudContentwarehouseV1UpdateDocumentRequest"
                      },
                      "response": {
                        "$ref": "GoogleCloudContentwarehouseV1UpdateDocumentResponse"
                      },
                      "id": "contentwarehouse.projects.locations.documents.referenceId.patch"
                    },
                    "get": {
                      "request": {
                        "$ref": "GoogleCloudContentwarehouseV1GetDocumentRequest"
                      },
                      "path": "v1/{+name}:get",
                      "parameters": {
                        "name": {
                          "type": "string",
                          "location": "path",
                          "pattern": "^projects/[^/]+/locations/[^/]+/documents/referenceId/[^/]+$",
                          "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}.",
                          "required": true
                        }
                      },
                      "description": "Gets a document. Returns NOT_FOUND if the document does not exist.",
                      "parameterOrder": [
                        "name"
                      ],
                      "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documents/referenceId/{referenceIdId}:get",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "httpMethod": "POST",
                      "response": {
                        "$ref": "GoogleCloudContentwarehouseV1Document"
                      },
                      "id": "contentwarehouse.projects.locations.documents.referenceId.get"
                    }
                  }
                }
              }
            },
            "documentSchemas": {
              "methods": {
                "create": {
                  "description": "Creates a document schema.",
                  "parameterOrder": [
                    "parent"
                  ],
                  "path": "v1/{+parent}/documentSchemas",
                  "id": "contentwarehouse.projects.locations.documentSchemas.create",
                  "parameters": {
                    "parent": {
                      "type": "string",
                      "location": "path",
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "required": true,
                      "description": "Required. The parent name."
                    }
                  },
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1DocumentSchema"
                  },
                  "httpMethod": "POST",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1DocumentSchema"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documentSchemas"
                },
                "delete": {
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documentSchemas/{documentSchemasId}",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "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"
                  ],
                  "parameters": {
                    "name": {
                      "required": true,
                      "pattern": "^projects/[^/]+/locations/[^/]+/documentSchemas/[^/]+$",
                      "description": "Required. The name of the document schema to delete.",
                      "type": "string",
                      "location": "path"
                    }
                  },
                  "id": "contentwarehouse.projects.locations.documentSchemas.delete",
                  "path": "v1/{+name}",
                  "response": {
                    "$ref": "GoogleProtobufEmpty"
                  },
                  "httpMethod": "DELETE"
                },
                "patch": {
                  "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.",
                  "request": {
                    "$ref": "GoogleCloudContentwarehouseV1UpdateDocumentSchemaRequest"
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documentSchemas/{documentSchemasId}",
                  "path": "v1/{+name}",
                  "parameters": {
                    "name": {
                      "pattern": "^projects/[^/]+/locations/[^/]+/documentSchemas/[^/]+$",
                      "description": "Required. The name of the document schema to update. Format: projects/{project_number}/locations/{location}/documentSchemas/{document_schema_id}.",
                      "required": true,
                      "type": "string",
                      "location": "path"
                    }
                  },
                  "id": "contentwarehouse.projects.locations.documentSchemas.patch",
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1DocumentSchema"
                  },
                  "httpMethod": "PATCH",
                  "parameterOrder": [
                    "name"
                  ]
                },
                "list": {
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1ListDocumentSchemasResponse"
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "parameterOrder": [
                    "parent"
                  ],
                  "httpMethod": "GET",
                  "id": "contentwarehouse.projects.locations.documentSchemas.list",
                  "path": "v1/{+parent}/documentSchemas",
                  "parameters": {
                    "pageToken": {
                      "type": "string",
                      "location": "query",
                      "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."
                    },
                    "pageSize": {
                      "type": "integer",
                      "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.",
                      "format": "int32",
                      "location": "query"
                    },
                    "parent": {
                      "type": "string",
                      "description": "Required. The parent, which owns this collection of document schemas. Format: projects/{project_number}/locations/{location}.",
                      "required": true,
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "location": "path"
                    }
                  },
                  "description": "Lists document schemas.",
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documentSchemas"
                },
                "get": {
                  "parameters": {
                    "name": {
                      "type": "string",
                      "location": "path",
                      "description": "Required. The name of the document schema to retrieve.",
                      "pattern": "^projects/[^/]+/locations/[^/]+/documentSchemas/[^/]+$",
                      "required": true
                    }
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/documentSchemas/{documentSchemasId}",
                  "description": "Gets a document schema. Returns NOT_FOUND if the document schema does not exist.",
                  "id": "contentwarehouse.projects.locations.documentSchemas.get",
                  "response": {
                    "$ref": "GoogleCloudContentwarehouseV1DocumentSchema"
                  },
                  "httpMethod": "GET",
                  "parameterOrder": [
                    "name"
                  ],
                  "path": "v1/{+name}"
                }
              }
            },
            "operations": {
              "methods": {
                "get": {
                  "httpMethod": "GET",
                  "parameters": {
                    "name": {
                      "type": "string",
                      "description": "The name of the operation resource.",
                      "location": "path",
                      "required": true,
                      "pattern": "^projects/[^/]+/locations/[^/]+/operations/[^/]+$"
                    }
                  },
                  "path": "v1/{+name}",
                  "id": "contentwarehouse.projects.locations.operations.get",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  },
                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/operations/{operationsId}",
                  "parameterOrder": [
                    "name"
                  ],
                  "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."
                }
              }
            }
          },
          "methods": {
            "initialize": {
              "id": "contentwarehouse.projects.locations.initialize",
              "parameterOrder": [
                "location"
              ],
              "httpMethod": "POST",
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "request": {
                "$ref": "GoogleCloudContentwarehouseV1InitializeProjectRequest"
              },
              "description": "Provisions resources for given tenant project. Returns a long running operation.",
              "response": {
                "$ref": "GoogleLongrunningOperation"
              },
              "path": "v1/{+location}:initialize",
              "flatPath": "v1/projects/{projectsId}/locations/{locationsId}:initialize",
              "parameters": {
                "location": {
                  "required": true,
                  "pattern": "^projects/[^/]+/locations/[^/]+$",
                  "type": "string",
                  "description": "Required. The location to be initialized Format: projects/{project_number}/locations/{location}.",
                  "location": "path"
                }
              }
            },
            "runPipeline": {
              "path": "v1/{+name}:runPipeline",
              "id": "contentwarehouse.projects.locations.runPipeline",
              "parameters": {
                "name": {
                  "pattern": "^projects/[^/]+/locations/[^/]+$",
                  "description": "Required. The resource name which owns the resources of the pipeline. Format: projects/{project_number}/locations/{location}.",
                  "required": true,
                  "type": "string",
                  "location": "path"
                }
              },
              "response": {
                "$ref": "GoogleLongrunningOperation"
              },
              "parameterOrder": [
                "name"
              ],
              "flatPath": "v1/projects/{projectsId}/locations/{locationsId}:runPipeline",
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "httpMethod": "POST",
              "request": {
                "$ref": "GoogleCloudContentwarehouseV1RunPipelineRequest"
              },
              "description": "Run a predefined pipeline."
            },
            "getStatus": {
              "response": {
                "$ref": "GoogleCloudContentwarehouseV1ProjectStatus"
              },
              "path": "v1/{+location}:getStatus",
              "flatPath": "v1/projects/{projectsId}/locations/{locationsId}:getStatus",
              "id": "contentwarehouse.projects.locations.getStatus",
              "parameters": {
                "location": {
                  "required": true,
                  "location": "path",
                  "pattern": "^projects/[^/]+/locations/[^/]+$",
                  "type": "string",
                  "description": "Required. The location to be queried Format: projects/{project_number}/locations/{location}."
                }
              },
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "parameterOrder": [
                "location"
              ],
              "description": "Get the project status.",
              "httpMethod": "GET"
            }
          }
        }
      }
    }
  },
  "description": "",
  "servicePath": "",
  "ownerDomain": "google.com",
  "kind": "discovery#restDescription",
  "title": "Document AI Warehouse API",
  "batchPath": "batch",
  "basePath": ""
}
