{ "batchPath": "batch", "protocol": "rest", "servicePath": "", "endpoints": [ { "endpointUrl": "https://africa-south1-run.googleapis.com/", "location": "africa-south1", "description": "Locational Endpoint" }, { "endpointUrl": "https://asia-east1-run.googleapis.com/", "location": "asia-east1", "description": "Locational Endpoint" }, { "endpointUrl": "https://asia-east2-run.googleapis.com/", "location": "asia-east2", "description": "Locational Endpoint" }, { "endpointUrl": "https://asia-northeast1-run.googleapis.com/", "location": "asia-northeast1", "description": "Locational Endpoint" }, { "endpointUrl": "https://asia-northeast2-run.googleapis.com/", "location": "asia-northeast2", "description": "Locational Endpoint" }, { "endpointUrl": "https://asia-northeast3-run.googleapis.com/", "location": "asia-northeast3", "description": "Locational Endpoint" }, { "endpointUrl": "https://asia-south1-run.googleapis.com/", "location": "asia-south1", "description": "Locational Endpoint" }, { "endpointUrl": "https://asia-south2-run.googleapis.com/", "location": "asia-south2", "description": "Locational Endpoint" }, { "endpointUrl": "https://asia-southeast1-run.googleapis.com/", "location": "asia-southeast1", "description": "Locational Endpoint" }, { "endpointUrl": "https://asia-southeast2-run.googleapis.com/", "location": "asia-southeast2", "description": "Locational Endpoint" }, { "endpointUrl": "https://australia-southeast1-run.googleapis.com/", "location": "australia-southeast1", "description": "Locational Endpoint" }, { "endpointUrl": "https://australia-southeast2-run.googleapis.com/", "location": "australia-southeast2", "description": "Locational Endpoint" }, { "endpointUrl": "https://europe-central2-run.googleapis.com/", "location": "europe-central2", "description": "Locational Endpoint" }, { "endpointUrl": "https://europe-north1-run.googleapis.com/", "location": "europe-north1", "description": "Locational Endpoint" }, { "endpointUrl": "https://europe-southwest1-run.googleapis.com/", "location": "europe-southwest1", "description": "Locational Endpoint" }, { "endpointUrl": "https://europe-west1-run.googleapis.com/", "location": "europe-west1", "description": "Locational Endpoint" }, { "endpointUrl": "https://europe-west10-run.googleapis.com/", "location": "europe-west10", "description": "Locational Endpoint" }, { "endpointUrl": "https://europe-west12-run.googleapis.com/", "location": "europe-west12", "description": "Locational Endpoint" }, { "endpointUrl": "https://europe-west2-run.googleapis.com/", "location": "europe-west2", "description": "Locational Endpoint" }, { "endpointUrl": "https://europe-west3-run.googleapis.com/", "location": "europe-west3", "description": "Locational Endpoint" }, { "endpointUrl": "https://europe-west4-run.googleapis.com/", "location": "europe-west4", "description": "Locational Endpoint" }, { "endpointUrl": "https://europe-west6-run.googleapis.com/", "location": "europe-west6", "description": "Locational Endpoint" }, { "endpointUrl": "https://europe-west8-run.googleapis.com/", "location": "europe-west8", "description": "Locational Endpoint" }, { "endpointUrl": "https://europe-west9-run.googleapis.com/", "location": "europe-west9", "description": "Locational Endpoint" }, { "endpointUrl": "https://me-central1-run.googleapis.com/", "location": "me-central1", "description": "Locational Endpoint" }, { "endpointUrl": "https://me-central2-run.googleapis.com/", "location": "me-central2", "description": "Locational Endpoint" }, { "endpointUrl": "https://me-west1-run.googleapis.com/", "location": "me-west1", "description": "Locational Endpoint" }, { "endpointUrl": "https://northamerica-northeast1-run.googleapis.com/", "location": "northamerica-northeast1", "description": "Locational Endpoint" }, { "endpointUrl": "https://northamerica-northeast2-run.googleapis.com/", "location": "northamerica-northeast2", "description": "Locational Endpoint" }, { "endpointUrl": "https://southamerica-east1-run.googleapis.com/", "location": "southamerica-east1", "description": "Locational Endpoint" }, { "endpointUrl": "https://southamerica-west1-run.googleapis.com/", "location": "southamerica-west1", "description": "Locational Endpoint" }, { "endpointUrl": "https://us-central1-run.googleapis.com/", "location": "us-central1", "description": "Locational Endpoint" }, { "endpointUrl": "https://us-east1-run.googleapis.com/", "location": "us-east1", "description": "Locational Endpoint" }, { "endpointUrl": "https://us-east4-run.googleapis.com/", "location": "us-east4", "description": "Locational Endpoint" }, { "endpointUrl": "https://us-east5-run.googleapis.com/", "location": "us-east5", "description": "Locational Endpoint" }, { "endpointUrl": "https://us-south1-run.googleapis.com/", "location": "us-south1", "description": "Locational Endpoint" }, { "endpointUrl": "https://us-west1-run.googleapis.com/", "location": "us-west1", "description": "Locational Endpoint" }, { "endpointUrl": "https://us-west2-run.googleapis.com/", "location": "us-west2", "description": "Locational Endpoint" }, { "endpointUrl": "https://us-west3-run.googleapis.com/", "location": "us-west3", "description": "Locational Endpoint" }, { "endpointUrl": "https://us-west4-run.googleapis.com/", "location": "us-west4", "description": "Locational Endpoint" } ], "kind": "discovery#restDescription", "parameters": { "access_token": { "type": "string", "description": "OAuth access token.", "location": "query" }, "alt": { "type": "string", "description": "Data format for response.", "default": "json", "enum": [ "json", "media", "proto" ], "enumDescriptions": [ "Responses with Content-Type of application/json", "Media download with context-dependent Content-Type", "Responses with Content-Type of application/x-protobuf" ], "location": "query" }, "callback": { "type": "string", "description": "JSONP", "location": "query" }, "fields": { "type": "string", "description": "Selector specifying which fields to include in a partial response.", "location": "query" }, "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" }, "oauth_token": { "type": "string", "description": "OAuth 2.0 token for the current user.", "location": "query" }, "prettyPrint": { "type": "boolean", "description": "Returns response with indentations and line breaks.", "default": "true", "location": "query" }, "quotaUser": { "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.", "location": "query" }, "upload_protocol": { "type": "string", "description": "Upload protocol for media (e.g. \"raw\", \"multipart\").", "location": "query" }, "uploadType": { "type": "string", "description": "Legacy upload protocol for media (e.g. \"media\", \"multipart\").", "location": "query" }, "$.xgafv": { "type": "string", "description": "V1 error format.", "enum": [ "1", "2" ], "enumDescriptions": [ "v1 error format", "v2 error format" ], "location": "query" } }, "ownerDomain": "google.com", "version_module": true, "basePath": "", "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." } } } }, "icons": { "x16": "http://www.google.com/images/icons/product/search-16.gif", "x32": "http://www.google.com/images/icons/product/search-32.gif" }, "id": "run:v1", "version": "v1", "resources": { "projects": { "resources": { "locations": { "methods": { "list": { "id": "run.projects.locations.list", "path": "v1/{+name}/locations", "flatPath": "v1/projects/{projectsId}/locations", "httpMethod": "GET", "parameters": { "name": { "description": "The resource that owns the locations collection, if applicable.", "pattern": "^projects/[^/]+$", "location": "path", "required": true, "type": "string" }, "filter": { "description": "A filter to narrow down results to a preferred subset. The filtering language accepts strings like `\"displayName=tokyo\"`, and is documented in more detail in [AIP-160](https://google.aip.dev/160).", "location": "query", "type": "string" }, "pageSize": { "description": "The maximum number of results to return. If not set, the service selects a default.", "location": "query", "type": "integer", "format": "int32" }, "pageToken": { "description": "A page token received from the `next_page_token` field in the response. Send that page token to receive the subsequent page.", "location": "query", "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "ListLocationsResponse" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Lists information about the supported locations for this service." } }, "resources": { "operations": { "methods": { "list": { "id": "run.projects.locations.operations.list", "path": "v1/{+name}/operations", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/operations", "httpMethod": "GET", "parameters": { "name": { "description": "Required. To query for all of the operations for a project.", "pattern": "^projects/[^/]+/locations/[^/]+$", "location": "path", "required": true, "type": "string" }, "filter": { "description": "Optional. A filter for matching the completed or in-progress operations. The supported formats of *filter* are: To query for only completed operations: done:true To query for only ongoing operations: done:false Must be empty to query for all of the latest operations for the given parent project.", "location": "query", "type": "string" }, "pageSize": { "description": "The maximum number of records that should be returned. Requested page size cannot exceed 100. If not set or set to less than or equal to 0, the default page size is 100. .", "location": "query", "type": "integer", "format": "int32" }, "pageToken": { "description": "Token identifying which result to start with, which is returned by a previous list call.", "location": "query", "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "GoogleLongrunningListOperationsResponse" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`." }, "get": { "id": "run.projects.locations.operations.get", "path": "v1/{+name}", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/operations/{operationsId}", "httpMethod": "GET", "parameters": { "name": { "description": "The name of the operation resource.", "pattern": "^projects/[^/]+/locations/[^/]+/operations/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "GoogleLongrunningOperation" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "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." }, "delete": { "id": "run.projects.locations.operations.delete", "path": "v1/{+name}", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/operations/{operationsId}", "httpMethod": "DELETE", "parameters": { "name": { "description": "The name of the operation resource to be deleted.", "pattern": "^projects/[^/]+/locations/[^/]+/operations/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "Empty" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Deletes a long-running operation. This method indicates that the client is no longer interested in the operation result. It does not cancel the operation. If the server doesn't support this method, it returns `google.rpc.Code.UNIMPLEMENTED`." }, "wait": { "id": "run.projects.locations.operations.wait", "path": "v1/{+name}:wait", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/operations/{operationsId}:wait", "httpMethod": "POST", "parameters": { "name": { "description": "The name of the operation resource to wait on.", "pattern": "^projects/[^/]+/locations/[^/]+/operations/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "name" ], "request": { "$ref": "GoogleLongrunningWaitOperationRequest" }, "response": { "$ref": "GoogleLongrunningOperation" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Waits until the specified long-running operation is done or reaches at most a specified timeout, returning the latest state. If the operation is already done, the latest state is immediately returned. If the timeout specified is greater than the default HTTP/RPC timeout, the HTTP/RPC timeout is used. If the server does not support this method, it returns `google.rpc.Code.UNIMPLEMENTED`. Note that this method is on a best-effort basis. It may return the latest state before the specified timeout (including immediately), meaning even an immediate response is no guarantee that the operation is done." } } }, "authorizeddomains": { "methods": { "list": { "id": "run.projects.locations.authorizeddomains.list", "path": "v1/{+parent}/authorizeddomains", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/authorizeddomains", "httpMethod": "GET", "parameters": { "parent": { "description": "Name of the parent Project resource. Example: `projects/myproject`.", "pattern": "^projects/[^/]+/locations/[^/]+$", "location": "path", "required": true, "type": "string" }, "pageSize": { "description": "Maximum results to return per page.", "location": "query", "type": "integer", "format": "int32" }, "pageToken": { "description": "Continuation token for fetching the next page of results.", "location": "query", "type": "string" } }, "parameterOrder": [ "parent" ], "response": { "$ref": "ListAuthorizedDomainsResponse" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "List authorized domains." } } }, "revisions": { "methods": { "list": { "id": "run.projects.locations.revisions.list", "path": "v1/{+parent}/revisions", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/revisions", "httpMethod": "GET", "parameters": { "parent": { "description": "The namespace from which the revisions should be listed. For Cloud Run (fully managed), replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^projects/[^/]+/locations/[^/]+$", "location": "path", "required": true, "type": "string" }, "limit": { "description": "Optional. The maximum number of records that should be returned.", "location": "query", "type": "integer", "format": "int32" }, "includeUninitialized": { "description": "Not currently used by Cloud Run.", "location": "query", "type": "boolean" }, "fieldSelector": { "description": "Allows to filter resources based on a specific value for a field name. Send this in a query string format. i.e. 'metadata.name%3Dlorem'. Not currently used by Cloud Run.", "location": "query", "type": "string" }, "labelSelector": { "description": "Allows to filter resources based on a label. Supported operations are =, !=, exists, in, and notIn.", "location": "query", "type": "string" }, "resourceVersion": { "description": "The baseline resource version from which the list or watch operation should start. Not currently used by Cloud Run.", "location": "query", "type": "string" }, "watch": { "description": "Flag that indicates that the client expects to watch this resource as well. Not currently used by Cloud Run.", "location": "query", "type": "boolean" }, "continue": { "description": "Optional. Encoded string to continue paging.", "location": "query", "type": "string" } }, "parameterOrder": [ "parent" ], "response": { "$ref": "ListRevisionsResponse" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "List revisions. Results are sorted by creation time, descending." }, "get": { "id": "run.projects.locations.revisions.get", "path": "v1/{+name}", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/revisions/{revisionsId}", "httpMethod": "GET", "parameters": { "name": { "description": "The name of the revision to retrieve. For Cloud Run (fully managed), replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^projects/[^/]+/locations/[^/]+/revisions/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "Revision" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Get information about a revision." }, "delete": { "id": "run.projects.locations.revisions.delete", "path": "v1/{+name}", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/revisions/{revisionsId}", "httpMethod": "DELETE", "parameters": { "name": { "description": "The name of the revision to delete. For Cloud Run (fully managed), replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^projects/[^/]+/locations/[^/]+/revisions/[^/]+$", "location": "path", "required": true, "type": "string" }, "propagationPolicy": { "description": "Specifies the propagation policy of delete. Cloud Run currently ignores this setting, and deletes in the background.", "location": "query", "type": "string" }, "kind": { "description": "Cloud Run currently ignores this parameter.", "location": "query", "type": "string" }, "apiVersion": { "description": "Cloud Run currently ignores this parameter.", "location": "query", "type": "string" }, "dryRun": { "description": "Indicates that the server should validate the request and populate default values without persisting the request. Supported values: `all`", "location": "query", "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "Status" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Delete a revision." } } }, "configurations": { "methods": { "list": { "id": "run.projects.locations.configurations.list", "path": "v1/{+parent}/configurations", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/configurations", "httpMethod": "GET", "parameters": { "parent": { "description": "The namespace from which the configurations should be listed. For Cloud Run, replace {namespace_id} with the project ID or number.", "pattern": "^projects/[^/]+/locations/[^/]+$", "location": "path", "required": true, "type": "string" }, "limit": { "description": "Optional. The maximum number of the records that should be returned.", "location": "query", "type": "integer", "format": "int32" }, "includeUninitialized": { "description": "Not supported by Cloud Run.", "location": "query", "type": "boolean" }, "fieldSelector": { "description": "Not supported by Cloud Run.", "location": "query", "type": "string" }, "labelSelector": { "description": "Allows to filter resources based on a label. Supported operations are =, !=, exists, in, and notIn.", "location": "query", "type": "string" }, "resourceVersion": { "description": "Not supported by Cloud Run.", "location": "query", "type": "string" }, "watch": { "description": "Not supported by Cloud Run.", "location": "query", "type": "boolean" }, "continue": { "description": "Optional. Encoded string to continue paging.", "location": "query", "type": "string" } }, "parameterOrder": [ "parent" ], "response": { "$ref": "ListConfigurationsResponse" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "List configurations. Results are sorted by creation time, descending." }, "get": { "id": "run.projects.locations.configurations.get", "path": "v1/{+name}", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/configurations/{configurationsId}", "httpMethod": "GET", "parameters": { "name": { "description": "The name of the configuration to retrieve. For Cloud Run, replace {namespace_id} with the project ID or number.", "pattern": "^projects/[^/]+/locations/[^/]+/configurations/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "Configuration" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Get information about a configuration." } } }, "domainmappings": { "methods": { "create": { "id": "run.projects.locations.domainmappings.create", "path": "v1/{+parent}/domainmappings", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/domainmappings", "httpMethod": "POST", "parameters": { "parent": { "description": "Required. The namespace in which the domain mapping should be created. For Cloud Run (fully managed), replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^projects/[^/]+/locations/[^/]+$", "location": "path", "required": true, "type": "string" }, "dryRun": { "description": "Indicates that the server should validate the request and populate default values without persisting the request. Supported values: `all`", "location": "query", "type": "string" } }, "parameterOrder": [ "parent" ], "request": { "$ref": "DomainMapping" }, "response": { "$ref": "DomainMapping" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Create a new domain mapping." }, "list": { "id": "run.projects.locations.domainmappings.list", "path": "v1/{+parent}/domainmappings", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/domainmappings", "httpMethod": "GET", "parameters": { "parent": { "description": "Required. The namespace from which the domain mappings should be listed. For Cloud Run (fully managed), replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^projects/[^/]+/locations/[^/]+$", "location": "path", "required": true, "type": "string" }, "limit": { "description": "Optional. The maximum number of records that should be returned.", "location": "query", "type": "integer", "format": "int32" }, "includeUninitialized": { "description": "Not currently used by Cloud Run.", "location": "query", "type": "boolean" }, "fieldSelector": { "description": "Allows to filter resources based on a specific value for a field name. Send this in a query string format. i.e. 'metadata.name%3Dlorem'. Not currently used by Cloud Run.", "location": "query", "type": "string" }, "labelSelector": { "description": "Allows to filter resources based on a label. Supported operations are =, !=, exists, in, and notIn.", "location": "query", "type": "string" }, "resourceVersion": { "description": "The baseline resource version from which the list or watch operation should start. Not currently used by Cloud Run.", "location": "query", "type": "string" }, "watch": { "description": "Flag that indicates that the client expects to watch this resource as well. Not currently used by Cloud Run.", "location": "query", "type": "boolean" }, "continue": { "description": "Optional. Encoded string to continue paging.", "location": "query", "type": "string" } }, "parameterOrder": [ "parent" ], "response": { "$ref": "ListDomainMappingsResponse" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "List all domain mappings." }, "get": { "id": "run.projects.locations.domainmappings.get", "path": "v1/{+name}", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/domainmappings/{domainmappingsId}", "httpMethod": "GET", "parameters": { "name": { "description": "Required. The name of the domain mapping to retrieve. For Cloud Run (fully managed), replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^projects/[^/]+/locations/[^/]+/domainmappings/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "DomainMapping" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Get information about a domain mapping." }, "delete": { "id": "run.projects.locations.domainmappings.delete", "path": "v1/{+name}", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/domainmappings/{domainmappingsId}", "httpMethod": "DELETE", "parameters": { "name": { "description": "Required. The name of the domain mapping to delete. For Cloud Run (fully managed), replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^projects/[^/]+/locations/[^/]+/domainmappings/[^/]+$", "location": "path", "required": true, "type": "string" }, "propagationPolicy": { "description": "Specifies the propagation policy of delete. Cloud Run currently ignores this setting, and deletes in the background. Please see kubernetes.io/docs/concepts/architecture/garbage-collection/ for more information.", "location": "query", "type": "string" }, "kind": { "description": "Cloud Run currently ignores this parameter.", "location": "query", "type": "string" }, "apiVersion": { "description": "Cloud Run currently ignores this parameter.", "location": "query", "type": "string" }, "dryRun": { "description": "Indicates that the server should validate the request and populate default values without persisting the request. Supported values: `all`", "location": "query", "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "Status" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Delete a domain mapping." } } }, "jobs": { "methods": { "getIamPolicy": { "id": "run.projects.locations.jobs.getIamPolicy", "path": "v1/{+resource}:getIamPolicy", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/jobs/{jobsId}:getIamPolicy", "httpMethod": "GET", "parameters": { "resource": { "description": "REQUIRED: The resource for which the policy is being requested. See [Resource names](https://cloud.google.com/apis/design/resource_names) for the appropriate value for this field.", "pattern": "^projects/[^/]+/locations/[^/]+/jobs/[^/]+$", "location": "path", "required": true, "type": "string" }, "options.requestedPolicyVersion": { "description": "Optional. The maximum policy version that will be used to format the policy. Valid values are 0, 1, and 3. Requests specifying an invalid value will be rejected. Requests for policies with any conditional role bindings must specify version 3. Policies with no conditional role bindings may specify any valid value or leave the field unset. The policy in the response might use the policy version that you specified, or it might use a lower policy version. For example, if you specify version 3, but the policy has no conditional role bindings, the response uses version 1. To learn which resources support conditions in their IAM policies, see the [IAM documentation](https://cloud.google.com/iam/help/conditions/resource-policies).", "location": "query", "type": "integer", "format": "int32" } }, "parameterOrder": [ "resource" ], "response": { "$ref": "Policy" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Get the IAM Access Control policy currently in effect for the given job. This result does not include any inherited policies." }, "setIamPolicy": { "id": "run.projects.locations.jobs.setIamPolicy", "path": "v1/{+resource}:setIamPolicy", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/jobs/{jobsId}:setIamPolicy", "httpMethod": "POST", "parameters": { "resource": { "description": "REQUIRED: The resource for which the policy is being specified. See [Resource names](https://cloud.google.com/apis/design/resource_names) for the appropriate value for this field.", "pattern": "^projects/[^/]+/locations/[^/]+/jobs/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "resource" ], "request": { "$ref": "SetIamPolicyRequest" }, "response": { "$ref": "Policy" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Sets the IAM Access control policy for the specified job. Overwrites any existing policy." }, "testIamPermissions": { "id": "run.projects.locations.jobs.testIamPermissions", "path": "v1/{+resource}:testIamPermissions", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/jobs/{jobsId}:testIamPermissions", "httpMethod": "POST", "parameters": { "resource": { "description": "REQUIRED: The resource for which the policy detail is being requested. See [Resource names](https://cloud.google.com/apis/design/resource_names) for the appropriate value for this field.", "pattern": "^projects/[^/]+/locations/[^/]+/jobs/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "resource" ], "request": { "$ref": "TestIamPermissionsRequest" }, "response": { "$ref": "TestIamPermissionsResponse" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Returns permissions that a caller has on the specified job. There are no permissions required for making this API call." } } }, "routes": { "methods": { "list": { "id": "run.projects.locations.routes.list", "path": "v1/{+parent}/routes", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/routes", "httpMethod": "GET", "parameters": { "parent": { "description": "The namespace from which the routes should be listed. For Cloud Run (fully managed), replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^projects/[^/]+/locations/[^/]+$", "location": "path", "required": true, "type": "string" }, "limit": { "description": "Optional. The maximum number of records that should be returned.", "location": "query", "type": "integer", "format": "int32" }, "includeUninitialized": { "description": "Not currently used by Cloud Run.", "location": "query", "type": "boolean" }, "fieldSelector": { "description": "Allows to filter resources based on a specific value for a field name. Send this in a query string format. i.e. 'metadata.name%3Dlorem'. Not currently used by Cloud Run.", "location": "query", "type": "string" }, "labelSelector": { "description": "Allows to filter resources based on a label. Supported operations are =, !=, exists, in, and notIn.", "location": "query", "type": "string" }, "resourceVersion": { "description": "The baseline resource version from which the list or watch operation should start. Not currently used by Cloud Run.", "location": "query", "type": "string" }, "watch": { "description": "Flag that indicates that the client expects to watch this resource as well. Not currently used by Cloud Run.", "location": "query", "type": "boolean" }, "continue": { "description": "Optional. Encoded string to continue paging.", "location": "query", "type": "string" } }, "parameterOrder": [ "parent" ], "response": { "$ref": "ListRoutesResponse" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "List routes. Results are sorted by creation time, descending." }, "get": { "id": "run.projects.locations.routes.get", "path": "v1/{+name}", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/routes/{routesId}", "httpMethod": "GET", "parameters": { "name": { "description": "The name of the route to retrieve. For Cloud Run (fully managed), replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^projects/[^/]+/locations/[^/]+/routes/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "Route" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Get information about a route." } } }, "services": { "methods": { "list": { "id": "run.projects.locations.services.list", "path": "v1/{+parent}/services", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/services", "httpMethod": "GET", "parameters": { "parent": { "description": "Required. The parent from where the resources should be listed. In Cloud Run, it may be one of the following: * `{project_id_or_number}` * `namespaces/{project_id_or_number}` * `namespaces/{project_id_or_number}/services` * `projects/{project_id_or_number}/locations/{region}` * `projects/{project_id_or_number}/regions/{region}`", "pattern": "^projects/[^/]+/locations/[^/]+$", "location": "path", "required": true, "type": "string" }, "limit": { "description": "The maximum number of records that should be returned.", "location": "query", "type": "integer", "format": "int32" }, "includeUninitialized": { "description": "Not supported, and ignored by Cloud Run.", "location": "query", "type": "boolean" }, "fieldSelector": { "description": "Not supported, and ignored by Cloud Run.", "location": "query", "type": "string" }, "labelSelector": { "description": "Allows to filter resources based on a label. Supported operations are =, !=, exists, in, and notIn.", "location": "query", "type": "string" }, "resourceVersion": { "description": "Not supported, and ignored by Cloud Run.", "location": "query", "type": "string" }, "watch": { "description": "Not supported, and ignored by Cloud Run.", "location": "query", "type": "boolean" }, "continue": { "description": "Encoded string to continue paging.", "location": "query", "type": "string" } }, "parameterOrder": [ "parent" ], "response": { "$ref": "ListServicesResponse" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Lists services for the given project and region. Results are sorted by creation time, descending." }, "get": { "id": "run.projects.locations.services.get", "path": "v1/{+name}", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/services/{servicesId}", "httpMethod": "GET", "parameters": { "name": { "description": "Required. The fully qualified name of the service to retrieve. It can be any of the following forms: * `namespaces/{project_id_or_number}/services/{service_name}` (only when the `endpoint` is regional) * `projects/{project_id_or_number}/locations/{region}/services/{service_name}` * `projects/{project_id_or_number}/regions/{region}/services/{service_name}`", "pattern": "^projects/[^/]+/locations/[^/]+/services/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "Service" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Gets information about a service." }, "create": { "id": "run.projects.locations.services.create", "path": "v1/{+parent}/services", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/services", "httpMethod": "POST", "parameters": { "parent": { "description": "Required. The resource's parent. In Cloud Run, it may be one of the following: * `{project_id_or_number}` * `namespaces/{project_id_or_number}` * `namespaces/{project_id_or_number}/services` * `projects/{project_id_or_number}/locations/{region}` * `projects/{project_id_or_number}/regions/{region}`", "pattern": "^projects/[^/]+/locations/[^/]+$", "location": "path", "required": true, "type": "string" }, "dryRun": { "description": "Indicates that the server should validate the request and populate default values without persisting the request. Supported values: `all`", "location": "query", "type": "string" } }, "parameterOrder": [ "parent" ], "request": { "$ref": "Service" }, "response": { "$ref": "Service" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Creates a new Service. Service creation will trigger a new deployment. Use GetService, and check service.status to determine if the Service is ready." }, "replaceService": { "id": "run.projects.locations.services.replaceService", "path": "v1/{+name}", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/services/{servicesId}", "httpMethod": "PUT", "parameters": { "name": { "description": "Required. The fully qualified name of the service to replace. It can be any of the following forms: * `namespaces/{project_id_or_number}/services/{service_name}` (only when the `endpoint` is regional) * `projects/{project_id_or_number}/locations/{region}/services/{service_name}` * `projects/{project_id_or_number}/regions/{region}/services/{service_name}`", "pattern": "^projects/[^/]+/locations/[^/]+/services/[^/]+$", "location": "path", "required": true, "type": "string" }, "dryRun": { "description": "Indicates that the server should validate the request and populate default values without persisting the request. Supported values: `all`", "location": "query", "type": "string" } }, "parameterOrder": [ "name" ], "request": { "$ref": "Service" }, "response": { "$ref": "Service" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Replaces a service. Only the spec and metadata labels and annotations are modifiable. After the Update request, Cloud Run will work to make the 'status' match the requested 'spec'. May provide metadata.resourceVersion to enforce update from last read for optimistic concurrency control." }, "delete": { "id": "run.projects.locations.services.delete", "path": "v1/{+name}", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/services/{servicesId}", "httpMethod": "DELETE", "parameters": { "name": { "description": "Required. The fully qualified name of the service to delete. It can be any of the following forms: * `namespaces/{project_id_or_number}/services/{service_name}` (only when the `endpoint` is regional) * `projects/{project_id_or_number}/locations/{region}/services/{service_name}` * `projects/{project_id_or_number}/regions/{region}/services/{service_name}`", "pattern": "^projects/[^/]+/locations/[^/]+/services/[^/]+$", "location": "path", "required": true, "type": "string" }, "propagationPolicy": { "description": "Not supported, and ignored by Cloud Run.", "location": "query", "type": "string" }, "kind": { "description": "Not supported, and ignored by Cloud Run.", "location": "query", "type": "string" }, "apiVersion": { "description": "Not supported, and ignored by Cloud Run.", "location": "query", "type": "string" }, "dryRun": { "description": "Indicates that the server should validate the request and populate default values without persisting the request. Supported values: `all`", "location": "query", "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "Status" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Deletes the provided service. This will cause the Service to stop serving traffic and will delete all associated Revisions." }, "getIamPolicy": { "id": "run.projects.locations.services.getIamPolicy", "path": "v1/{+resource}:getIamPolicy", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/services/{servicesId}:getIamPolicy", "httpMethod": "GET", "parameters": { "resource": { "description": "REQUIRED: The resource for which the policy is being requested. See [Resource names](https://cloud.google.com/apis/design/resource_names) for the appropriate value for this field.", "pattern": "^projects/[^/]+/locations/[^/]+/services/[^/]+$", "location": "path", "required": true, "type": "string" }, "options.requestedPolicyVersion": { "description": "Optional. The maximum policy version that will be used to format the policy. Valid values are 0, 1, and 3. Requests specifying an invalid value will be rejected. Requests for policies with any conditional role bindings must specify version 3. Policies with no conditional role bindings may specify any valid value or leave the field unset. The policy in the response might use the policy version that you specified, or it might use a lower policy version. For example, if you specify version 3, but the policy has no conditional role bindings, the response uses version 1. To learn which resources support conditions in their IAM policies, see the [IAM documentation](https://cloud.google.com/iam/help/conditions/resource-policies).", "location": "query", "type": "integer", "format": "int32" } }, "parameterOrder": [ "resource" ], "response": { "$ref": "Policy" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Gets the IAM Access Control policy currently in effect for the given Cloud Run service. This result does not include any inherited policies." }, "setIamPolicy": { "id": "run.projects.locations.services.setIamPolicy", "path": "v1/{+resource}:setIamPolicy", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/services/{servicesId}:setIamPolicy", "httpMethod": "POST", "parameters": { "resource": { "description": "REQUIRED: The resource for which the policy is being specified. See [Resource names](https://cloud.google.com/apis/design/resource_names) for the appropriate value for this field.", "pattern": "^projects/[^/]+/locations/[^/]+/services/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "resource" ], "request": { "$ref": "SetIamPolicyRequest" }, "response": { "$ref": "Policy" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Sets the IAM Access control policy for the specified Service. Overwrites any existing policy." }, "testIamPermissions": { "id": "run.projects.locations.services.testIamPermissions", "path": "v1/{+resource}:testIamPermissions", "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/services/{servicesId}:testIamPermissions", "httpMethod": "POST", "parameters": { "resource": { "description": "REQUIRED: The resource for which the policy detail is being requested. See [Resource names](https://cloud.google.com/apis/design/resource_names) for the appropriate value for this field.", "pattern": "^projects/[^/]+/locations/[^/]+/services/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "resource" ], "request": { "$ref": "TestIamPermissionsRequest" }, "response": { "$ref": "TestIamPermissionsResponse" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Returns permissions that a caller has on the specified Project. There are no permissions required for making this API call." } } } } }, "authorizeddomains": { "methods": { "list": { "id": "run.projects.authorizeddomains.list", "path": "v1/{+parent}/authorizeddomains", "flatPath": "v1/projects/{projectsId}/authorizeddomains", "httpMethod": "GET", "parameters": { "parent": { "description": "Name of the parent Project resource. Example: `projects/myproject`.", "pattern": "^projects/[^/]+$", "location": "path", "required": true, "type": "string" }, "pageSize": { "description": "Maximum results to return per page.", "location": "query", "type": "integer", "format": "int32" }, "pageToken": { "description": "Continuation token for fetching the next page of results.", "location": "query", "type": "string" } }, "parameterOrder": [ "parent" ], "response": { "$ref": "ListAuthorizedDomainsResponse" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "List authorized domains." } } } } }, "namespaces": { "resources": { "authorizeddomains": { "methods": { "list": { "id": "run.namespaces.authorizeddomains.list", "path": "apis/domains.cloudrun.com/v1/{+parent}/authorizeddomains", "flatPath": "apis/domains.cloudrun.com/v1/namespaces/{namespacesId}/authorizeddomains", "httpMethod": "GET", "parameters": { "parent": { "description": "Name of the parent Project resource. Example: `projects/myproject`.", "pattern": "^namespaces/[^/]+$", "location": "path", "required": true, "type": "string" }, "pageSize": { "description": "Maximum results to return per page.", "location": "query", "type": "integer", "format": "int32" }, "pageToken": { "description": "Continuation token for fetching the next page of results.", "location": "query", "type": "string" } }, "parameterOrder": [ "parent" ], "response": { "$ref": "ListAuthorizedDomainsResponse" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "List authorized domains." } } }, "revisions": { "methods": { "list": { "id": "run.namespaces.revisions.list", "path": "apis/serving.knative.dev/v1/{+parent}/revisions", "flatPath": "apis/serving.knative.dev/v1/namespaces/{namespacesId}/revisions", "httpMethod": "GET", "parameters": { "parent": { "description": "The namespace from which the revisions should be listed. For Cloud Run (fully managed), replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^namespaces/[^/]+$", "location": "path", "required": true, "type": "string" }, "limit": { "description": "Optional. The maximum number of records that should be returned.", "location": "query", "type": "integer", "format": "int32" }, "includeUninitialized": { "description": "Not currently used by Cloud Run.", "location": "query", "type": "boolean" }, "fieldSelector": { "description": "Allows to filter resources based on a specific value for a field name. Send this in a query string format. i.e. 'metadata.name%3Dlorem'. Not currently used by Cloud Run.", "location": "query", "type": "string" }, "labelSelector": { "description": "Allows to filter resources based on a label. Supported operations are =, !=, exists, in, and notIn.", "location": "query", "type": "string" }, "resourceVersion": { "description": "The baseline resource version from which the list or watch operation should start. Not currently used by Cloud Run.", "location": "query", "type": "string" }, "watch": { "description": "Flag that indicates that the client expects to watch this resource as well. Not currently used by Cloud Run.", "location": "query", "type": "boolean" }, "continue": { "description": "Optional. Encoded string to continue paging.", "location": "query", "type": "string" } }, "parameterOrder": [ "parent" ], "response": { "$ref": "ListRevisionsResponse" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "List revisions. Results are sorted by creation time, descending." }, "get": { "id": "run.namespaces.revisions.get", "path": "apis/serving.knative.dev/v1/{+name}", "flatPath": "apis/serving.knative.dev/v1/namespaces/{namespacesId}/revisions/{revisionsId}", "httpMethod": "GET", "parameters": { "name": { "description": "The name of the revision to retrieve. For Cloud Run (fully managed), replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^namespaces/[^/]+/revisions/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "Revision" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Get information about a revision." }, "delete": { "id": "run.namespaces.revisions.delete", "path": "apis/serving.knative.dev/v1/{+name}", "flatPath": "apis/serving.knative.dev/v1/namespaces/{namespacesId}/revisions/{revisionsId}", "httpMethod": "DELETE", "parameters": { "name": { "description": "The name of the revision to delete. For Cloud Run (fully managed), replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^namespaces/[^/]+/revisions/[^/]+$", "location": "path", "required": true, "type": "string" }, "propagationPolicy": { "description": "Specifies the propagation policy of delete. Cloud Run currently ignores this setting, and deletes in the background.", "location": "query", "type": "string" }, "kind": { "description": "Cloud Run currently ignores this parameter.", "location": "query", "type": "string" }, "apiVersion": { "description": "Cloud Run currently ignores this parameter.", "location": "query", "type": "string" }, "dryRun": { "description": "Indicates that the server should validate the request and populate default values without persisting the request. Supported values: `all`", "location": "query", "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "Status" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Delete a revision." } } }, "configurations": { "methods": { "list": { "id": "run.namespaces.configurations.list", "path": "apis/serving.knative.dev/v1/{+parent}/configurations", "flatPath": "apis/serving.knative.dev/v1/namespaces/{namespacesId}/configurations", "httpMethod": "GET", "parameters": { "parent": { "description": "The namespace from which the configurations should be listed. For Cloud Run, replace {namespace_id} with the project ID or number.", "pattern": "^namespaces/[^/]+$", "location": "path", "required": true, "type": "string" }, "limit": { "description": "Optional. The maximum number of the records that should be returned.", "location": "query", "type": "integer", "format": "int32" }, "includeUninitialized": { "description": "Not supported by Cloud Run.", "location": "query", "type": "boolean" }, "fieldSelector": { "description": "Not supported by Cloud Run.", "location": "query", "type": "string" }, "labelSelector": { "description": "Allows to filter resources based on a label. Supported operations are =, !=, exists, in, and notIn.", "location": "query", "type": "string" }, "resourceVersion": { "description": "Not supported by Cloud Run.", "location": "query", "type": "string" }, "watch": { "description": "Not supported by Cloud Run.", "location": "query", "type": "boolean" }, "continue": { "description": "Optional. Encoded string to continue paging.", "location": "query", "type": "string" } }, "parameterOrder": [ "parent" ], "response": { "$ref": "ListConfigurationsResponse" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "List configurations. Results are sorted by creation time, descending." }, "get": { "id": "run.namespaces.configurations.get", "path": "apis/serving.knative.dev/v1/{+name}", "flatPath": "apis/serving.knative.dev/v1/namespaces/{namespacesId}/configurations/{configurationsId}", "httpMethod": "GET", "parameters": { "name": { "description": "The name of the configuration to retrieve. For Cloud Run, replace {namespace_id} with the project ID or number.", "pattern": "^namespaces/[^/]+/configurations/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "Configuration" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Get information about a configuration." } } }, "domainmappings": { "methods": { "create": { "id": "run.namespaces.domainmappings.create", "path": "apis/domains.cloudrun.com/v1/{+parent}/domainmappings", "flatPath": "apis/domains.cloudrun.com/v1/namespaces/{namespacesId}/domainmappings", "httpMethod": "POST", "parameters": { "parent": { "description": "Required. The namespace in which the domain mapping should be created. For Cloud Run (fully managed), replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^namespaces/[^/]+$", "location": "path", "required": true, "type": "string" }, "dryRun": { "description": "Indicates that the server should validate the request and populate default values without persisting the request. Supported values: `all`", "location": "query", "type": "string" } }, "parameterOrder": [ "parent" ], "request": { "$ref": "DomainMapping" }, "response": { "$ref": "DomainMapping" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Create a new domain mapping." }, "list": { "id": "run.namespaces.domainmappings.list", "path": "apis/domains.cloudrun.com/v1/{+parent}/domainmappings", "flatPath": "apis/domains.cloudrun.com/v1/namespaces/{namespacesId}/domainmappings", "httpMethod": "GET", "parameters": { "parent": { "description": "Required. The namespace from which the domain mappings should be listed. For Cloud Run (fully managed), replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^namespaces/[^/]+$", "location": "path", "required": true, "type": "string" }, "limit": { "description": "Optional. The maximum number of records that should be returned.", "location": "query", "type": "integer", "format": "int32" }, "includeUninitialized": { "description": "Not currently used by Cloud Run.", "location": "query", "type": "boolean" }, "fieldSelector": { "description": "Allows to filter resources based on a specific value for a field name. Send this in a query string format. i.e. 'metadata.name%3Dlorem'. Not currently used by Cloud Run.", "location": "query", "type": "string" }, "labelSelector": { "description": "Allows to filter resources based on a label. Supported operations are =, !=, exists, in, and notIn.", "location": "query", "type": "string" }, "resourceVersion": { "description": "The baseline resource version from which the list or watch operation should start. Not currently used by Cloud Run.", "location": "query", "type": "string" }, "watch": { "description": "Flag that indicates that the client expects to watch this resource as well. Not currently used by Cloud Run.", "location": "query", "type": "boolean" }, "continue": { "description": "Optional. Encoded string to continue paging.", "location": "query", "type": "string" } }, "parameterOrder": [ "parent" ], "response": { "$ref": "ListDomainMappingsResponse" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "List all domain mappings." }, "get": { "id": "run.namespaces.domainmappings.get", "path": "apis/domains.cloudrun.com/v1/{+name}", "flatPath": "apis/domains.cloudrun.com/v1/namespaces/{namespacesId}/domainmappings/{domainmappingsId}", "httpMethod": "GET", "parameters": { "name": { "description": "Required. The name of the domain mapping to retrieve. For Cloud Run (fully managed), replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^namespaces/[^/]+/domainmappings/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "DomainMapping" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Get information about a domain mapping." }, "delete": { "id": "run.namespaces.domainmappings.delete", "path": "apis/domains.cloudrun.com/v1/{+name}", "flatPath": "apis/domains.cloudrun.com/v1/namespaces/{namespacesId}/domainmappings/{domainmappingsId}", "httpMethod": "DELETE", "parameters": { "name": { "description": "Required. The name of the domain mapping to delete. For Cloud Run (fully managed), replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^namespaces/[^/]+/domainmappings/[^/]+$", "location": "path", "required": true, "type": "string" }, "propagationPolicy": { "description": "Specifies the propagation policy of delete. Cloud Run currently ignores this setting, and deletes in the background. Please see kubernetes.io/docs/concepts/architecture/garbage-collection/ for more information.", "location": "query", "type": "string" }, "kind": { "description": "Cloud Run currently ignores this parameter.", "location": "query", "type": "string" }, "apiVersion": { "description": "Cloud Run currently ignores this parameter.", "location": "query", "type": "string" }, "dryRun": { "description": "Indicates that the server should validate the request and populate default values without persisting the request. Supported values: `all`", "location": "query", "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "Status" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Delete a domain mapping." } } }, "tasks": { "methods": { "get": { "id": "run.namespaces.tasks.get", "path": "apis/run.googleapis.com/v1/{+name}", "flatPath": "apis/run.googleapis.com/v1/namespaces/{namespacesId}/tasks/{tasksId}", "httpMethod": "GET", "parameters": { "name": { "description": "Required. The name of the task to retrieve. Replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^namespaces/[^/]+/tasks/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "Task" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Get information about a task." }, "list": { "id": "run.namespaces.tasks.list", "path": "apis/run.googleapis.com/v1/{+parent}/tasks", "flatPath": "apis/run.googleapis.com/v1/namespaces/{namespacesId}/tasks", "httpMethod": "GET", "parameters": { "parent": { "description": "Required. The namespace from which the tasks should be listed. Replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^namespaces/[^/]+$", "location": "path", "required": true, "type": "string" }, "limit": { "description": "Optional. The maximum number of records that should be returned.", "location": "query", "type": "integer", "format": "int32" }, "includeUninitialized": { "description": "Optional. Not supported by Cloud Run.", "location": "query", "type": "boolean" }, "fieldSelector": { "description": "Optional. Not supported by Cloud Run.", "location": "query", "type": "string" }, "labelSelector": { "description": "Optional. Allows to filter resources based on a label. Supported operations are =, !=, exists, in, and notIn. For example, to list all tasks of execution \"foo\" in succeeded state: `run.googleapis.com/execution=foo,run.googleapis.com/runningState=Succeeded`. Supported states are: * `Pending`: Initial state of all tasks. The task has not yet started but eventually will. * `Running`: Container instances for this task are running or will be running shortly. * `Succeeded`: No more container instances to run for the task, and the last attempt succeeded. * `Failed`: No more container instances to run for the task, and the last attempt failed. This task has run out of retry attempts. * `Cancelled`: Task was running but got stopped because its parent execution has been aborted. * `Abandoned`: The task has not yet started and never will because its parent execution has been aborted.", "location": "query", "type": "string" }, "resourceVersion": { "description": "Optional. Not supported by Cloud Run.", "location": "query", "type": "string" }, "watch": { "description": "Optional. Not supported by Cloud Run.", "location": "query", "type": "boolean" }, "continue": { "description": "Optional. Optional encoded string to continue paging.", "location": "query", "type": "string" } }, "parameterOrder": [ "parent" ], "response": { "$ref": "ListTasksResponse" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "List tasks." } } }, "executions": { "methods": { "delete": { "id": "run.namespaces.executions.delete", "path": "apis/run.googleapis.com/v1/{+name}", "flatPath": "apis/run.googleapis.com/v1/namespaces/{namespacesId}/executions/{executionsId}", "httpMethod": "DELETE", "parameters": { "name": { "description": "Required. The name of the execution to delete. Replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^namespaces/[^/]+/executions/[^/]+$", "location": "path", "required": true, "type": "string" }, "propagationPolicy": { "description": "Optional. Specifies the propagation policy of delete. Cloud Run currently ignores this setting.", "location": "query", "type": "string" }, "kind": { "description": "Optional. Cloud Run currently ignores this parameter.", "location": "query", "type": "string" }, "apiVersion": { "description": "Optional. Cloud Run currently ignores this parameter.", "location": "query", "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "Status" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Delete an execution." }, "get": { "id": "run.namespaces.executions.get", "path": "apis/run.googleapis.com/v1/{+name}", "flatPath": "apis/run.googleapis.com/v1/namespaces/{namespacesId}/executions/{executionsId}", "httpMethod": "GET", "parameters": { "name": { "description": "Required. The name of the execution to retrieve. Replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^namespaces/[^/]+/executions/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "Execution" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Get information about an execution." }, "list": { "id": "run.namespaces.executions.list", "path": "apis/run.googleapis.com/v1/{+parent}/executions", "flatPath": "apis/run.googleapis.com/v1/namespaces/{namespacesId}/executions", "httpMethod": "GET", "parameters": { "parent": { "description": "Required. The namespace from which the executions should be listed. Replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^namespaces/[^/]+$", "location": "path", "required": true, "type": "string" }, "limit": { "description": "Optional. The maximum number of the records that should be returned.", "location": "query", "type": "integer", "format": "int32" }, "includeUninitialized": { "description": "Optional. Not supported by Cloud Run.", "location": "query", "type": "boolean" }, "fieldSelector": { "description": "Optional. Not supported by Cloud Run.", "location": "query", "type": "string" }, "labelSelector": { "description": "Optional. Allows to filter resources based on a label. Supported operations are =, !=, exists, in, and notIn.", "location": "query", "type": "string" }, "resourceVersion": { "description": "Optional. Not supported by Cloud Run.", "location": "query", "type": "string" }, "watch": { "description": "Optional. Not supported by Cloud Run.", "location": "query", "type": "boolean" }, "continue": { "description": "Optional. Optional encoded string to continue paging.", "location": "query", "type": "string" } }, "parameterOrder": [ "parent" ], "response": { "$ref": "ListExecutionsResponse" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "List executions. Results are sorted by creation time, descending." }, "cancel": { "id": "run.namespaces.executions.cancel", "path": "apis/run.googleapis.com/v1/{+name}:cancel", "flatPath": "apis/run.googleapis.com/v1/namespaces/{namespacesId}/executions/{executionsId}:cancel", "httpMethod": "POST", "parameters": { "name": { "description": "Required. The name of the execution to cancel. Replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^namespaces/[^/]+/executions/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "name" ], "request": { "$ref": "CancelExecutionRequest" }, "response": { "$ref": "Execution" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Cancel an execution." } } }, "jobs": { "methods": { "create": { "id": "run.namespaces.jobs.create", "path": "apis/run.googleapis.com/v1/{+parent}/jobs", "flatPath": "apis/run.googleapis.com/v1/namespaces/{namespacesId}/jobs", "httpMethod": "POST", "parameters": { "parent": { "description": "Required. The namespace in which the job should be created. Replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^namespaces/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "parent" ], "request": { "$ref": "Job" }, "response": { "$ref": "Job" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Create a job." }, "replaceJob": { "id": "run.namespaces.jobs.replaceJob", "path": "apis/run.googleapis.com/v1/{+name}", "flatPath": "apis/run.googleapis.com/v1/namespaces/{namespacesId}/jobs/{jobsId}", "httpMethod": "PUT", "parameters": { "name": { "description": "Required. The name of the job being replaced. Replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^namespaces/[^/]+/jobs/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "name" ], "request": { "$ref": "Job" }, "response": { "$ref": "Job" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Replace a job. Only the spec and metadata labels and annotations are modifiable. After the Replace request, Cloud Run will work to make the 'status' match the requested 'spec'. May provide metadata.resourceVersion to enforce update from last read for optimistic concurrency control." }, "delete": { "id": "run.namespaces.jobs.delete", "path": "apis/run.googleapis.com/v1/{+name}", "flatPath": "apis/run.googleapis.com/v1/namespaces/{namespacesId}/jobs/{jobsId}", "httpMethod": "DELETE", "parameters": { "name": { "description": "Required. The name of the job to delete. Replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^namespaces/[^/]+/jobs/[^/]+$", "location": "path", "required": true, "type": "string" }, "propagationPolicy": { "description": "Optional. Specifies the propagation policy of delete. Cloud Run currently ignores this setting, and deletes in the background. Please see kubernetes.io/docs/concepts/workloads/controllers/garbage-collection/ for more information.", "location": "query", "type": "string" }, "kind": { "description": "Optional. Cloud Run currently ignores this parameter.", "location": "query", "type": "string" }, "apiVersion": { "description": "Optional. Cloud Run currently ignores this parameter.", "location": "query", "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "Status" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Delete a job." }, "get": { "id": "run.namespaces.jobs.get", "path": "apis/run.googleapis.com/v1/{+name}", "flatPath": "apis/run.googleapis.com/v1/namespaces/{namespacesId}/jobs/{jobsId}", "httpMethod": "GET", "parameters": { "name": { "description": "Required. The name of the job to retrieve. Replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^namespaces/[^/]+/jobs/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "Job" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Get information about a job." }, "list": { "id": "run.namespaces.jobs.list", "path": "apis/run.googleapis.com/v1/{+parent}/jobs", "flatPath": "apis/run.googleapis.com/v1/namespaces/{namespacesId}/jobs", "httpMethod": "GET", "parameters": { "parent": { "description": "Required. The namespace from which the jobs should be listed. Replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^namespaces/[^/]+$", "location": "path", "required": true, "type": "string" }, "limit": { "description": "Optional. The maximum number of records that should be returned.", "location": "query", "type": "integer", "format": "int32" }, "includeUninitialized": { "description": "Optional. Not supported by Cloud Run.", "location": "query", "type": "boolean" }, "fieldSelector": { "description": "Optional. Not supported by Cloud Run.", "location": "query", "type": "string" }, "labelSelector": { "description": "Optional. Allows to filter resources based on a label. Supported operations are =, !=, exists, in, and notIn.", "location": "query", "type": "string" }, "resourceVersion": { "description": "Optional. Not supported by Cloud Run.", "location": "query", "type": "string" }, "watch": { "description": "Optional. Not supported by Cloud Run.", "location": "query", "type": "boolean" }, "continue": { "description": "Optional. Optional encoded string to continue paging.", "location": "query", "type": "string" } }, "parameterOrder": [ "parent" ], "response": { "$ref": "ListJobsResponse" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "List jobs. Results are sorted by creation time, descending." }, "run": { "id": "run.namespaces.jobs.run", "path": "apis/run.googleapis.com/v1/{+name}:run", "flatPath": "apis/run.googleapis.com/v1/namespaces/{namespacesId}/jobs/{jobsId}:run", "httpMethod": "POST", "parameters": { "name": { "description": "Required. The name of the job to run. Replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^namespaces/[^/]+/jobs/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "name" ], "request": { "$ref": "RunJobRequest" }, "response": { "$ref": "Execution" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Trigger creation of a new execution of this job." } } }, "routes": { "methods": { "list": { "id": "run.namespaces.routes.list", "path": "apis/serving.knative.dev/v1/{+parent}/routes", "flatPath": "apis/serving.knative.dev/v1/namespaces/{namespacesId}/routes", "httpMethod": "GET", "parameters": { "parent": { "description": "The namespace from which the routes should be listed. For Cloud Run (fully managed), replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^namespaces/[^/]+$", "location": "path", "required": true, "type": "string" }, "limit": { "description": "Optional. The maximum number of records that should be returned.", "location": "query", "type": "integer", "format": "int32" }, "includeUninitialized": { "description": "Not currently used by Cloud Run.", "location": "query", "type": "boolean" }, "fieldSelector": { "description": "Allows to filter resources based on a specific value for a field name. Send this in a query string format. i.e. 'metadata.name%3Dlorem'. Not currently used by Cloud Run.", "location": "query", "type": "string" }, "labelSelector": { "description": "Allows to filter resources based on a label. Supported operations are =, !=, exists, in, and notIn.", "location": "query", "type": "string" }, "resourceVersion": { "description": "The baseline resource version from which the list or watch operation should start. Not currently used by Cloud Run.", "location": "query", "type": "string" }, "watch": { "description": "Flag that indicates that the client expects to watch this resource as well. Not currently used by Cloud Run.", "location": "query", "type": "boolean" }, "continue": { "description": "Optional. Encoded string to continue paging.", "location": "query", "type": "string" } }, "parameterOrder": [ "parent" ], "response": { "$ref": "ListRoutesResponse" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "List routes. Results are sorted by creation time, descending." }, "get": { "id": "run.namespaces.routes.get", "path": "apis/serving.knative.dev/v1/{+name}", "flatPath": "apis/serving.knative.dev/v1/namespaces/{namespacesId}/routes/{routesId}", "httpMethod": "GET", "parameters": { "name": { "description": "The name of the route to retrieve. For Cloud Run (fully managed), replace {namespace} with the project ID or number. It takes the form namespaces/{namespace}. For example: namespaces/PROJECT_ID", "pattern": "^namespaces/[^/]+/routes/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "Route" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Get information about a route." } } }, "services": { "methods": { "list": { "id": "run.namespaces.services.list", "path": "apis/serving.knative.dev/v1/{+parent}/services", "flatPath": "apis/serving.knative.dev/v1/namespaces/{namespacesId}/services", "httpMethod": "GET", "parameters": { "parent": { "description": "Required. The parent from where the resources should be listed. In Cloud Run, it may be one of the following: * `{project_id_or_number}` * `namespaces/{project_id_or_number}` * `namespaces/{project_id_or_number}/services` * `projects/{project_id_or_number}/locations/{region}` * `projects/{project_id_or_number}/regions/{region}`", "pattern": "^namespaces/[^/]+$", "location": "path", "required": true, "type": "string" }, "limit": { "description": "The maximum number of records that should be returned.", "location": "query", "type": "integer", "format": "int32" }, "includeUninitialized": { "description": "Not supported, and ignored by Cloud Run.", "location": "query", "type": "boolean" }, "fieldSelector": { "description": "Not supported, and ignored by Cloud Run.", "location": "query", "type": "string" }, "labelSelector": { "description": "Allows to filter resources based on a label. Supported operations are =, !=, exists, in, and notIn.", "location": "query", "type": "string" }, "resourceVersion": { "description": "Not supported, and ignored by Cloud Run.", "location": "query", "type": "string" }, "watch": { "description": "Not supported, and ignored by Cloud Run.", "location": "query", "type": "boolean" }, "continue": { "description": "Encoded string to continue paging.", "location": "query", "type": "string" } }, "parameterOrder": [ "parent" ], "response": { "$ref": "ListServicesResponse" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Lists services for the given project and region. Results are sorted by creation time, descending." }, "get": { "id": "run.namespaces.services.get", "path": "apis/serving.knative.dev/v1/{+name}", "flatPath": "apis/serving.knative.dev/v1/namespaces/{namespacesId}/services/{servicesId}", "httpMethod": "GET", "parameters": { "name": { "description": "Required. The fully qualified name of the service to retrieve. It can be any of the following forms: * `namespaces/{project_id_or_number}/services/{service_name}` (only when the `endpoint` is regional) * `projects/{project_id_or_number}/locations/{region}/services/{service_name}` * `projects/{project_id_or_number}/regions/{region}/services/{service_name}`", "pattern": "^namespaces/[^/]+/services/[^/]+$", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "Service" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Gets information about a service." }, "create": { "id": "run.namespaces.services.create", "path": "apis/serving.knative.dev/v1/{+parent}/services", "flatPath": "apis/serving.knative.dev/v1/namespaces/{namespacesId}/services", "httpMethod": "POST", "parameters": { "parent": { "description": "Required. The resource's parent. In Cloud Run, it may be one of the following: * `{project_id_or_number}` * `namespaces/{project_id_or_number}` * `namespaces/{project_id_or_number}/services` * `projects/{project_id_or_number}/locations/{region}` * `projects/{project_id_or_number}/regions/{region}`", "pattern": "^namespaces/[^/]+$", "location": "path", "required": true, "type": "string" }, "dryRun": { "description": "Indicates that the server should validate the request and populate default values without persisting the request. Supported values: `all`", "location": "query", "type": "string" } }, "parameterOrder": [ "parent" ], "request": { "$ref": "Service" }, "response": { "$ref": "Service" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Creates a new Service. Service creation will trigger a new deployment. Use GetService, and check service.status to determine if the Service is ready." }, "replaceService": { "id": "run.namespaces.services.replaceService", "path": "apis/serving.knative.dev/v1/{+name}", "flatPath": "apis/serving.knative.dev/v1/namespaces/{namespacesId}/services/{servicesId}", "httpMethod": "PUT", "parameters": { "name": { "description": "Required. The fully qualified name of the service to replace. It can be any of the following forms: * `namespaces/{project_id_or_number}/services/{service_name}` (only when the `endpoint` is regional) * `projects/{project_id_or_number}/locations/{region}/services/{service_name}` * `projects/{project_id_or_number}/regions/{region}/services/{service_name}`", "pattern": "^namespaces/[^/]+/services/[^/]+$", "location": "path", "required": true, "type": "string" }, "dryRun": { "description": "Indicates that the server should validate the request and populate default values without persisting the request. Supported values: `all`", "location": "query", "type": "string" } }, "parameterOrder": [ "name" ], "request": { "$ref": "Service" }, "response": { "$ref": "Service" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Replaces a service. Only the spec and metadata labels and annotations are modifiable. After the Update request, Cloud Run will work to make the 'status' match the requested 'spec'. May provide metadata.resourceVersion to enforce update from last read for optimistic concurrency control." }, "delete": { "id": "run.namespaces.services.delete", "path": "apis/serving.knative.dev/v1/{+name}", "flatPath": "apis/serving.knative.dev/v1/namespaces/{namespacesId}/services/{servicesId}", "httpMethod": "DELETE", "parameters": { "name": { "description": "Required. The fully qualified name of the service to delete. It can be any of the following forms: * `namespaces/{project_id_or_number}/services/{service_name}` (only when the `endpoint` is regional) * `projects/{project_id_or_number}/locations/{region}/services/{service_name}` * `projects/{project_id_or_number}/regions/{region}/services/{service_name}`", "pattern": "^namespaces/[^/]+/services/[^/]+$", "location": "path", "required": true, "type": "string" }, "propagationPolicy": { "description": "Not supported, and ignored by Cloud Run.", "location": "query", "type": "string" }, "kind": { "description": "Not supported, and ignored by Cloud Run.", "location": "query", "type": "string" }, "apiVersion": { "description": "Not supported, and ignored by Cloud Run.", "location": "query", "type": "string" }, "dryRun": { "description": "Indicates that the server should validate the request and populate default values without persisting the request. Supported values: `all`", "location": "query", "type": "string" } }, "parameterOrder": [ "name" ], "response": { "$ref": "Status" }, "scopes": [ "https://www.googleapis.com/auth/cloud-platform" ], "description": "Deletes the provided service. This will cause the Service to stop serving traffic and will delete all associated Revisions." } } } } } }, "baseUrl": "https://run.googleapis.com/", "fullyEncodeReservedExpansion": true, "mtlsRootUrl": "https://run.mtls.googleapis.com/", "name": "run", "documentationLink": "https://cloud.google.com/run/", "discoveryVersion": "v1", "canonicalName": "Cloud Run", "title": "Cloud Run Admin API", "revision": "20241115", "schemas": { "ListLocationsResponse": { "id": "ListLocationsResponse", "description": "The response message for Locations.ListLocations.", "type": "object", "properties": { "locations": { "description": "A list of locations that matches the specified filter in the request.", "type": "array", "items": { "$ref": "Location" } }, "nextPageToken": { "description": "The standard List next-page token.", "type": "string" } } }, "Location": { "id": "Location", "description": "A resource that represents a Google Cloud location.", "type": "object", "properties": { "name": { "description": "Resource name for the location, which may vary between implementations. For example: `\"projects/example-project/locations/us-east1\"`", "type": "string" }, "locationId": { "description": "The canonical id for this location. For example: `\"us-east1\"`.", "type": "string" }, "displayName": { "description": "The friendly name for this location, typically a nearby city name. For example, \"Tokyo\".", "type": "string" }, "labels": { "description": "Cross-service attributes for the location. For example {\"cloud.googleapis.com/region\": \"us-east1\"}", "type": "object", "additionalProperties": { "type": "string" } }, "metadata": { "description": "Service-specific metadata. For example the available capacity at the given location.", "type": "object", "additionalProperties": { "type": "any", "description": "Properties of the object. Contains field @type with type URL." } } } }, "GoogleLongrunningListOperationsResponse": { "id": "GoogleLongrunningListOperationsResponse", "description": "The response message for Operations.ListOperations.", "type": "object", "properties": { "operations": { "description": "A list of operations that matches the specified filter in the request.", "type": "array", "items": { "$ref": "GoogleLongrunningOperation" } }, "nextPageToken": { "description": "The standard List next-page token.", "type": "string" } } }, "GoogleLongrunningOperation": { "id": "GoogleLongrunningOperation", "description": "This resource represents a long-running operation that is the result of a network API call.", "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" }, "metadata": { "description": "Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any.", "type": "object", "additionalProperties": { "type": "any", "description": "Properties of the object. Contains field @type with type URL." } }, "done": { "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.", "type": "boolean" }, "error": { "description": "The error result of the operation in case of failure or cancellation.", "$ref": "GoogleRpcStatus" }, "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`.", "type": "object", "additionalProperties": { "type": "any", "description": "Properties of the object. Contains field @type with type URL." } } } }, "GoogleRpcStatus": { "id": "GoogleRpcStatus", "description": "The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors).", "type": "object", "properties": { "code": { "description": "The status code, which should be an enum value of google.rpc.Code.", "type": "integer", "format": "int32" }, "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" }, "details": { "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use.", "type": "array", "items": { "type": "object", "additionalProperties": { "type": "any", "description": "Properties of the object. Contains field @type with type URL." } } } } }, "Empty": { "id": "Empty", "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", "properties": {} }, "GoogleLongrunningWaitOperationRequest": { "id": "GoogleLongrunningWaitOperationRequest", "description": "The request message for Operations.WaitOperation.", "type": "object", "properties": { "timeout": { "description": "The maximum duration to wait before timing out. If left blank, the wait will be at most the time permitted by the underlying HTTP/RPC protocol. If RPC context deadline is also specified, the shorter one will be used.", "type": "string", "format": "google-duration" } } }, "ListAuthorizedDomainsResponse": { "id": "ListAuthorizedDomainsResponse", "description": "A list of Authorized Domains.", "type": "object", "properties": { "domains": { "description": "The authorized domains belonging to the user.", "type": "array", "items": { "$ref": "AuthorizedDomain" } }, "nextPageToken": { "description": "Continuation token for fetching the next page of results.", "type": "string" } } }, "AuthorizedDomain": { "id": "AuthorizedDomain", "description": "A domain that a user has been authorized to administer. To authorize use of a domain, verify ownership via [Search Console](https://search.google.com/search-console/welcome).", "type": "object", "properties": { "name": { "description": "Deprecated Read only. Full path to the `AuthorizedDomain` resource in the API. Example: `projects/myproject/authorizedDomains/example.com`.", "deprecated": true, "type": "string" }, "id": { "description": "Relative name of the domain authorized for use. Example: `example.com`.", "type": "string" } } }, "ListRevisionsResponse": { "id": "ListRevisionsResponse", "description": "ListRevisionsResponse is a list of Revision resources.", "type": "object", "properties": { "apiVersion": { "description": "The API version for this call such as \"serving.knative.dev/v1\".", "type": "string" }, "kind": { "description": "The kind of this resource, in this case \"RevisionList\".", "type": "string" }, "metadata": { "description": "Metadata associated with this revision list.", "$ref": "ListMeta" }, "items": { "description": "List of Revisions.", "type": "array", "items": { "$ref": "Revision" } }, "unreachable": { "description": "Locations that could not be reached.", "type": "array", "items": { "type": "string" } } } }, "ListMeta": { "id": "ListMeta", "description": "Metadata for synthetic resources like List. In Cloud Run, all List Resources Responses will have a ListMeta instead of ObjectMeta.", "type": "object", "properties": { "selfLink": { "description": "URL representing this object.", "type": "string" }, "resourceVersion": { "description": "Opaque string that identifies the server's internal version of this object. It can be used by clients to determine when objects have changed. If the message is passed back to the server, it must be left unmodified.", "type": "string" }, "continue": { "description": "Continuation token is a value emitted when the count of items is larger than the user/system limit. To retrieve the next page of items, pass the value of `continue` as the next request's `page_token`.", "type": "string" } } }, "Revision": { "id": "Revision", "description": "Revision is an immutable snapshot of code and configuration. A revision references a container image. Revisions are created by updates to a Configuration. See also: https://github.com/knative/specs/blob/main/specs/serving/overview.md#revision", "type": "object", "properties": { "apiVersion": { "description": "The API version for this call such as \"serving.knative.dev/v1\".", "type": "string" }, "kind": { "description": "The kind of this resource, in this case \"Revision\".", "type": "string" }, "metadata": { "description": "Metadata associated with this Revision, including name, namespace, labels, and annotations.", "$ref": "ObjectMeta" }, "spec": { "description": "Spec holds the desired state of the Revision (from the client).", "$ref": "RevisionSpec" }, "status": { "description": "Status communicates the observed state of the Revision (from the controller).", "$ref": "RevisionStatus" } } }, "ObjectMeta": { "id": "ObjectMeta", "description": "google.cloud.run.meta.v1.ObjectMeta is metadata that all persisted resources must have, which includes all objects users must create.", "type": "object", "properties": { "name": { "description": "Required. The name of the resource. Name is required when creating top-level resources (Service, Job), must be unique within a Cloud Run project/region, and cannot be changed once created.", "type": "string" }, "generateName": { "description": "Not supported by Cloud Run", "type": "string" }, "namespace": { "description": "Required. Defines the space within each name must be unique within a Cloud Run region. In Cloud Run, it must be project ID or number.", "type": "string" }, "selfLink": { "description": "URL representing this object.", "type": "string" }, "uid": { "description": "Unique, system-generated identifier for this resource.", "type": "string" }, "resourceVersion": { "description": "Opaque, system-generated value that represents the internal version of this object that can be used by clients to determine when objects have changed. May be used for optimistic concurrency, change detection, and the watch operation on a resource or set of resources. Clients must treat these values as opaque and passed unmodified back to the server or omit the value to disable conflict-detection.", "type": "string" }, "generation": { "description": "A system-provided sequence number representing a specific generation of the desired state.", "type": "integer", "format": "int32" }, "creationTimestamp": { "description": "UTC timestamp representing the server time when this object was created.", "type": "string", "format": "google-datetime" }, "labels": { "description": "Map of string keys and values that can be used to organize and categorize (scope and select) objects. May match selectors of replication controllers and routes.", "type": "object", "additionalProperties": { "type": "string" } }, "annotations": { "description": "Unstructured key value map stored with a resource that may be set by external tools to store and retrieve arbitrary metadata. They are not queryable and should be preserved when modifying objects. In Cloud Run, annotations with 'run.googleapis.com/' and 'autoscaling.knative.dev' are restricted, and the accepted annotations will be different depending on the resource type. * `autoscaling.knative.dev/maxScale`: Revision. * `autoscaling.knative.dev/minScale`: Revision. * `run.googleapis.com/base-images`: Service, Revision. * `run.googleapis.com/binary-authorization-breakglass`: Service, Job, * `run.googleapis.com/binary-authorization`: Service, Job, Execution. * `run.googleapis.com/build-base-image`: Service. * `run.googleapis.com/build-enable-automatic-updates`: Service. * `run.googleapis.com/build-environment-variables`: Service. * `run.googleapis.com/build-function-target`: Service. * `run.googleapis.com/build-id`: Service. * `run.googleapis.com/build-image-uri`: Service. * `run.googleapis.com/build-name`: Service. * `run.googleapis.com/build-service-account`: Service. * `run.googleapis.com/build-source-location`: Service. * `run.googleapis.com/build-worker-pool`: Service. * `run.googleapis.com/client-name`: All resources. * `run.googleapis.com/cloudsql-instances`: Revision, Execution. * `run.googleapis.com/container-dependencies`: Revision . * `run.googleapis.com/cpu-throttling`: Revision. * `run.googleapis.com/custom-audiences`: Service. * `run.googleapis.com/default-url-disabled`: Service. * `run.googleapis.com/description`: Service. * `run.googleapis.com/encryption-key-shutdown-hours`: Revision * `run.googleapis.com/encryption-key`: Revision, Execution. * `run.googleapis.com/execution-environment`: Revision, Execution. * `run.googleapis.com/gc-traffic-tags`: Service. * `run.googleapis.com/health-check-disabled`: Revision. * `run.googleapis.com/ingress`: Service. * `run.googleapis.com/launch-stage`: Service, Job. * `run.googleapis.com/minScale`: Service * `run.googleapis.com/network-interfaces`: Revision, Execution. * `run.googleapis.com/post-key-revocation-action-type`: Revision. * `run.googleapis.com/secrets`: Revision, Execution. * `run.googleapis.com/secure-session-agent`: Revision. * `run.googleapis.com/sessionAffinity`: Revision. * `run.googleapis.com/startup-cpu-boost`: Revision. * `run.googleapis.com/vpc-access-connector`: Revision, Execution. * `run.googleapis.com/vpc-access-egress`: Revision, Execution.", "type": "object", "additionalProperties": { "type": "string" } }, "ownerReferences": { "description": "Not supported by Cloud Run", "type": "array", "items": { "$ref": "OwnerReference" } }, "deletionTimestamp": { "description": "The read-only soft deletion timestamp for this resource. In Cloud Run, users are not able to set this field. Instead, they must call the corresponding Delete API.", "type": "string", "format": "google-datetime" }, "deletionGracePeriodSeconds": { "description": "Not supported by Cloud Run", "type": "integer", "format": "int32" }, "finalizers": { "description": "Not supported by Cloud Run", "type": "array", "items": { "type": "string" } }, "clusterName": { "description": "Not supported by Cloud Run", "type": "string" } } }, "OwnerReference": { "id": "OwnerReference", "description": "This is not supported or used by Cloud Run.", "type": "object", "properties": { "apiVersion": { "description": "This is not supported or used by Cloud Run.", "type": "string" }, "kind": { "description": "This is not supported or used by Cloud Run.", "type": "string" }, "name": { "description": "This is not supported or used by Cloud Run.", "type": "string" }, "uid": { "description": "This is not supported or used by Cloud Run.", "type": "string" }, "controller": { "description": "This is not supported or used by Cloud Run.", "type": "boolean" }, "blockOwnerDeletion": { "description": "This is not supported or used by Cloud Run.", "type": "boolean" } } }, "RevisionSpec": { "id": "RevisionSpec", "description": "RevisionSpec holds the desired state of the Revision (from the client).", "type": "object", "properties": { "containerConcurrency": { "description": "ContainerConcurrency specifies the maximum allowed in-flight (concurrent) requests per container instance of the Revision. If not specified or 0, defaults to 80 when requested CPU \u003e= 1 and defaults to 1 when requested CPU \u003c 1.", "type": "integer", "format": "int32" }, "timeoutSeconds": { "description": "TimeoutSeconds holds the max duration the instance is allowed for responding to a request. Cloud Run: defaults to 300 seconds (5 minutes). Maximum allowed value is 3600 seconds (1 hour).", "type": "integer", "format": "int32" }, "serviceAccountName": { "description": "Email address of the IAM service account associated with the revision of the service. The service account represents the identity of the running revision, and determines what permissions the revision has. If not provided, the revision will use the project's default service account.", "type": "string" }, "containers": { "description": "Required. Containers holds the list which define the units of execution for this Revision. In the context of a Revision, we disallow a number of fields on this Container, including: name and lifecycle.", "type": "array", "items": { "$ref": "Container" } }, "volumes": { "type": "array", "items": { "$ref": "Volume" } }, "runtimeClassName": { "description": "Runtime. Leave unset for default.", "type": "string" }, "enableServiceLinks": { "description": "Not supported by Cloud Run.", "type": "boolean" }, "imagePullSecrets": { "description": "Not supported by Cloud Run.", "type": "array", "items": { "$ref": "LocalObjectReference" } }, "nodeSelector": { "description": "Optional. The Node Selector configuration. Map of selector key to a value which matches a node.", "type": "object", "additionalProperties": { "type": "string" } } } }, "Container": { "id": "Container", "description": "A single application container. This specifies both the container to run, the command to run in the container and the arguments to supply to it. Note that additional arguments may be supplied by the system to the container at runtime.", "type": "object", "properties": { "name": { "description": "Name of the container specified as a DNS_LABEL (RFC 1123).", "type": "string" }, "image": { "description": "Required. Name of the container image in Dockerhub, Google Artifact Registry, or Google Container Registry. If the host is not provided, Dockerhub is assumed.", "type": "string" }, "command": { "description": "Entrypoint array. Not executed within a shell. The docker image's ENTRYPOINT is used if this is not provided. Variable references are not supported in Cloud Run.", "type": "array", "items": { "type": "string" } }, "args": { "description": "Arguments to the entrypoint. The docker image's CMD is used if this is not provided. Variable references are not supported in Cloud Run.", "type": "array", "items": { "type": "string" } }, "env": { "description": "List of environment variables to set in the container. EnvVar with duplicate names are generally allowed; if referencing a secret, the name must be unique for the container. For non-secret EnvVar names, the Container will only get the last-declared one.", "type": "array", "items": { "$ref": "EnvVar" } }, "resources": { "description": "Compute Resources required by this container.", "$ref": "ResourceRequirements" }, "workingDir": { "description": "Container's working directory. If not specified, the container runtime's default will be used, which might be configured in the container image.", "type": "string" }, "ports": { "description": "List of ports to expose from the container. Only a single port can be specified. The specified ports must be listening on all interfaces (0.0.0.0) within the container to be accessible. If omitted, a port number will be chosen and passed to the container through the PORT environment variable for the container to listen on.", "type": "array", "items": { "$ref": "ContainerPort" } }, "envFrom": { "description": "Not supported by Cloud Run.", "type": "array", "items": { "$ref": "EnvFromSource" } }, "volumeMounts": { "description": "Volume to mount into the container's filesystem. Only supports SecretVolumeSources. Pod volumes to mount into the container's filesystem.", "type": "array", "items": { "$ref": "VolumeMount" } }, "livenessProbe": { "description": "Periodic probe of container liveness. Container will be restarted if the probe fails.", "$ref": "Probe" }, "readinessProbe": { "description": "Readiness probe to be used for health checks. Not supported by Cloud Run.", "$ref": "Probe" }, "startupProbe": { "description": "Startup probe of application within the container. All other probes are disabled if a startup probe is provided, until it succeeds. Container will not receive traffic if the probe fails. If not provided, a default startup probe with TCP socket action is used.", "$ref": "Probe" }, "terminationMessagePath": { "description": "Path at which the file to which the container's termination message will be written is mounted into the container's filesystem. Message written is intended to be brief final status, such as an assertion failure message. Will be truncated by the node if greater than 4096 bytes. The total message length across all containers will be limited to 12kb. Defaults to /dev/termination-log.", "type": "string" }, "terminationMessagePolicy": { "description": "Indicate how the termination message should be populated. File will use the contents of terminationMessagePath to populate the container status message on both success and failure. FallbackToLogsOnError will use the last chunk of container log output if the termination message file is empty and the container exited with an error. The log output is limited to 2048 bytes or 80 lines, whichever is smaller. Defaults to File. Cannot be updated.", "type": "string" }, "imagePullPolicy": { "description": "Image pull policy. One of Always, Never, IfNotPresent. Defaults to Always if :latest tag is specified, or IfNotPresent otherwise.", "type": "string" }, "securityContext": { "description": "Not supported by Cloud Run.", "$ref": "SecurityContext" } } }, "EnvVar": { "id": "EnvVar", "description": "EnvVar represents an environment variable present in a Container.", "type": "object", "properties": { "name": { "description": "Required. Name of the environment variable.", "type": "string" }, "value": { "description": "Value of the environment variable. Defaults to \"\". Variable references are not supported in Cloud Run.", "type": "string" }, "valueFrom": { "description": "Source for the environment variable's value. Only supports secret_key_ref. Cannot be used if value is not empty.", "$ref": "EnvVarSource" } } }, "EnvVarSource": { "id": "EnvVarSource", "description": "EnvVarSource represents a source for the value of an EnvVar.", "type": "object", "properties": { "configMapKeyRef": { "description": "Not supported by Cloud Run. Not supported in Cloud Run.", "$ref": "ConfigMapKeySelector" }, "secretKeyRef": { "description": "Selects a key (version) of a secret in Secret Manager.", "$ref": "SecretKeySelector" } } }, "ConfigMapKeySelector": { "id": "ConfigMapKeySelector", "description": "Not supported by Cloud Run.", "type": "object", "properties": { "localObjectReference": { "description": "Not supported by Cloud Run.", "deprecated": true, "$ref": "LocalObjectReference" }, "key": { "description": "Required. Not supported by Cloud Run.", "type": "string" }, "optional": { "description": "Not supported by Cloud Run.", "type": "boolean" }, "name": { "description": "Required. Not supported by Cloud Run.", "type": "string" } } }, "LocalObjectReference": { "id": "LocalObjectReference", "description": "Not supported by Cloud Run. LocalObjectReference contains enough information to let you locate the referenced object inside the same namespace.", "type": "object", "properties": { "name": { "description": "Name of the referent.", "type": "string" } } }, "SecretKeySelector": { "id": "SecretKeySelector", "description": "SecretKeySelector selects a key of a Secret.", "type": "object", "properties": { "localObjectReference": { "description": "This field should not be used directly as it is meant to be inlined directly into the message. Use the \"name\" field instead.", "deprecated": true, "$ref": "LocalObjectReference" }, "key": { "description": "Required. A Cloud Secret Manager secret version. Must be 'latest' for the latest version, an integer for a specific version, or a version alias. The key of the secret to select from. Must be a valid secret key.", "type": "string" }, "optional": { "description": "Specify whether the Secret or its key must be defined.", "type": "boolean" }, "name": { "description": "The name of the secret in Cloud Secret Manager. By default, the secret is assumed to be in the same project. If the secret is in another project, you must define an alias. An alias definition has the form: :projects//secrets/. If multiple alias definitions are needed, they must be separated by commas. The alias definitions must be set on the run.googleapis.com/secrets annotation. The name of the secret in the pod's namespace to select from.", "type": "string" } } }, "ResourceRequirements": { "id": "ResourceRequirements", "description": "ResourceRequirements describes the compute resource requirements.", "type": "object", "properties": { "limits": { "description": "Limits describes the maximum amount of compute resources allowed. Only 'cpu' and 'memory' keys are supported. * For supported 'cpu' values, go to https://cloud.google.com/run/docs/configuring/cpu. * For supported 'memory' values and syntax, go to https://cloud.google.com/run/docs/configuring/memory-limits", "type": "object", "additionalProperties": { "type": "string" } }, "requests": { "description": "Requests describes the minimum amount of compute resources required. Only `cpu` and `memory` are supported. If Requests is omitted for a container, it defaults to Limits if that is explicitly specified, otherwise to an implementation-defined value. * For supported 'cpu' values, go to https://cloud.google.com/run/docs/configuring/cpu. * For supported 'memory' values and syntax, go to https://cloud.google.com/run/docs/configuring/memory-limits", "type": "object", "additionalProperties": { "type": "string" } } } }, "ContainerPort": { "id": "ContainerPort", "description": "ContainerPort represents a network port in a single container.", "type": "object", "properties": { "name": { "description": "If specified, used to specify which protocol to use. Allowed values are \"http1\" and \"h2c\".", "type": "string" }, "containerPort": { "description": "Port number the container listens on. If present, this must be a valid port number, 0 \u003c x \u003c 65536. If not present, it will default to port 8080. For more information, see https://cloud.google.com/run/docs/container-contract#port", "type": "integer", "format": "int32" }, "protocol": { "description": "Protocol for port. Must be \"TCP\". Defaults to \"TCP\".", "type": "string" } } }, "EnvFromSource": { "id": "EnvFromSource", "description": "Not supported by Cloud Run. EnvFromSource represents the source of a set of ConfigMaps", "type": "object", "properties": { "prefix": { "description": "An optional identifier to prepend to each key in the ConfigMap. Must be a C_IDENTIFIER.", "type": "string" }, "configMapRef": { "description": "The ConfigMap to select from", "$ref": "ConfigMapEnvSource" }, "secretRef": { "description": "The Secret to select from", "$ref": "SecretEnvSource" } } }, "ConfigMapEnvSource": { "id": "ConfigMapEnvSource", "description": "Not supported by Cloud Run. ConfigMapEnvSource selects a ConfigMap to populate the environment variables with. The contents of the target ConfigMap's Data field will represent the key-value pairs as environment variables.", "type": "object", "properties": { "localObjectReference": { "description": "This field should not be used directly as it is meant to be inlined directly into the message. Use the \"name\" field instead.", "deprecated": true, "$ref": "LocalObjectReference" }, "optional": { "description": "Specify whether the ConfigMap must be defined.", "type": "boolean" }, "name": { "description": "The ConfigMap to select from.", "type": "string" } } }, "SecretEnvSource": { "id": "SecretEnvSource", "description": "Not supported by Cloud Run. SecretEnvSource selects a Secret to populate the environment variables with. The contents of the target Secret's Data field will represent the key-value pairs as environment variables.", "type": "object", "properties": { "localObjectReference": { "description": "This field should not be used directly as it is meant to be inlined directly into the message. Use the \"name\" field instead.", "deprecated": true, "$ref": "LocalObjectReference" }, "optional": { "description": "Specify whether the Secret must be defined", "type": "boolean" }, "name": { "description": "The Secret to select from.", "type": "string" } } }, "VolumeMount": { "id": "VolumeMount", "description": "VolumeMount describes a mounting of a Volume within a container.", "type": "object", "properties": { "name": { "description": "Required. The name of the volume. There must be a corresponding Volume with the same name.", "type": "string" }, "readOnly": { "description": "Sets the mount to be read-only or read-write. Not used by Cloud Run.", "type": "boolean" }, "mountPath": { "description": "Required. Path within the container at which the volume should be mounted. Must not contain ':'.", "type": "string" }, "subPath": { "description": "Path within the volume from which the container's volume should be mounted. Defaults to \"\" (volume's root).", "type": "string" } } }, "Probe": { "id": "Probe", "description": "Probe describes a health check to be performed against a container to determine whether it is alive or ready to receive traffic.", "type": "object", "properties": { "initialDelaySeconds": { "description": "Number of seconds after the container has started before the probe is initiated. Defaults to 0 seconds. Minimum value is 0. Maximum value for liveness probe is 3600. Maximum value for startup probe is 240.", "type": "integer", "format": "int32" }, "timeoutSeconds": { "description": "Number of seconds after which the probe times out. Defaults to 1 second. Minimum value is 1. Maximum value is 3600. Must be smaller than period_seconds; if period_seconds is not set, must be less or equal than 10.", "type": "integer", "format": "int32" }, "periodSeconds": { "description": "How often (in seconds) to perform the probe. Default to 10 seconds. Minimum value is 1. Maximum value for liveness probe is 3600. Maximum value for startup probe is 240. Must be greater or equal than timeout_seconds.", "type": "integer", "format": "int32" }, "successThreshold": { "description": "Minimum consecutive successes for the probe to be considered successful after having failed. Must be 1 if set.", "type": "integer", "format": "int32" }, "failureThreshold": { "description": "Minimum consecutive failures for the probe to be considered failed after having succeeded. Defaults to 3. Minimum value is 1.", "type": "integer", "format": "int32" }, "exec": { "description": "Not supported by Cloud Run.", "$ref": "ExecAction" }, "httpGet": { "description": "HTTPGet specifies the http request to perform.", "$ref": "HTTPGetAction" }, "tcpSocket": { "description": "TCPSocket specifies an action involving a TCP port.", "$ref": "TCPSocketAction" }, "grpc": { "description": "GRPCAction specifies an action involving a GRPC port.", "$ref": "GRPCAction" } } }, "ExecAction": { "id": "ExecAction", "description": "Not supported by Cloud Run. ExecAction describes a \"run in container\" action.", "type": "object", "properties": { "command": { "description": "Command is the command line to execute inside the container, the working directory for the command is root ('/') in the container's filesystem. The command is simply exec'd, it is not run inside a shell, so traditional shell instructions ('|', etc) won't work. To use a shell, you need to explicitly call out to that shell. Exit status of 0 is treated as live/healthy and non-zero is unhealthy.", "type": "array", "items": { "type": "string" } } } }, "HTTPGetAction": { "id": "HTTPGetAction", "description": "HTTPGetAction describes an action based on HTTP Get requests.", "type": "object", "properties": { "path": { "description": "Path to access on the HTTP server.", "type": "string" }, "host": { "description": "Not supported by Cloud Run.", "type": "string" }, "scheme": { "description": "Not supported by Cloud Run.", "type": "string" }, "httpHeaders": { "description": "Custom headers to set in the request. HTTP allows repeated headers.", "type": "array", "items": { "$ref": "HTTPHeader" } }, "port": { "description": "Port number to access on the container. Number must be in the range 1 to 65535.", "type": "integer", "format": "int32" } } }, "HTTPHeader": { "id": "HTTPHeader", "description": "HTTPHeader describes a custom header to be used in HTTP probes", "type": "object", "properties": { "name": { "description": "Required. The header field name", "type": "string" }, "value": { "description": "The header field value", "type": "string" } } }, "TCPSocketAction": { "id": "TCPSocketAction", "description": "TCPSocketAction describes an action based on opening a socket", "type": "object", "properties": { "port": { "description": "Port number to access on the container. Number must be in the range 1 to 65535.", "type": "integer", "format": "int32" }, "host": { "description": "Not supported by Cloud Run.", "type": "string" } } }, "GRPCAction": { "id": "GRPCAction", "description": "GRPCAction describes an action involving a GRPC port.", "type": "object", "properties": { "port": { "description": "Port number of the gRPC service. Number must be in the range 1 to 65535.", "type": "integer", "format": "int32" }, "service": { "description": "Service is the name of the service to place in the gRPC HealthCheckRequest. If this is not specified, the default behavior is defined by gRPC.", "type": "string" } } }, "SecurityContext": { "id": "SecurityContext", "description": "Not supported by Cloud Run. SecurityContext holds security configuration that will be applied to a container. Some fields are present in both SecurityContext and PodSecurityContext. When both are set, the values in SecurityContext take precedence.", "type": "object", "properties": { "runAsUser": { "description": "The UID to run the entrypoint of the container process. Defaults to user specified in image metadata if unspecified. May also be set in PodSecurityContext. If set in both SecurityContext and PodSecurityContext, the value specified in SecurityContext takes precedence.", "type": "integer", "format": "int32" } } }, "Volume": { "id": "Volume", "description": "Volume represents a named volume in a container.", "type": "object", "properties": { "name": { "description": "Volume's name. In Cloud Run Fully Managed, the name 'cloudsql' is reserved.", "type": "string" }, "secret": { "description": "The secret's value will be presented as the content of a file whose name is defined in the item path. If no items are defined, the name of the file is the secretName.", "$ref": "SecretVolumeSource" }, "configMap": { "description": "Not supported in Cloud Run.", "$ref": "ConfigMapVolumeSource" }, "emptyDir": { "description": "Ephemeral storage used as a shared volume.", "$ref": "EmptyDirVolumeSource" }, "nfs": { "$ref": "NFSVolumeSource" }, "csi": { "description": "Volume specified by the Container Storage Interface driver", "$ref": "CSIVolumeSource" } } }, "SecretVolumeSource": { "id": "SecretVolumeSource", "description": "A volume representing a secret stored in Google Secret Manager. The secret's value will be presented as the content of a file whose name is defined in the item path. If no items are defined, the name of the file is the secret_name. The contents of the target Secret's Data field will be presented in a volume as files using the keys in the Data field as the file names.", "type": "object", "properties": { "secretName": { "description": "The name of the secret in Cloud Secret Manager. By default, the secret is assumed to be in the same project. If the secret is in another project, you must define an alias. An alias definition has the form: :projects//secrets/. If multiple alias definitions are needed, they must be separated by commas. The alias definitions must be set on the run.googleapis.com/secrets annotation. Name of the secret in the container's namespace to use.", "type": "string" }, "items": { "description": "A list of secret versions to mount in the volume. If no items are specified, the volume will expose a file with the same name as the secret name. The contents of the file will be the data in the latest version of the secret. If items are specified, the key will be used as the version to fetch from Cloud Secret Manager and the path will be the name of the file exposed in the volume. When items are defined, they must specify both a key and a path.", "type": "array", "items": { "$ref": "KeyToPath" } }, "defaultMode": { "description": "Integer representation of mode bits to use on created files by default. Must be a value between 01 and 0777 (octal). If 0 or not set, it will default to 0444. Directories within the path are not affected by this setting. Notes * Internally, a umask of 0222 will be applied to any non-zero value. * This is an integer representation of the mode bits. So, the octal integer value should look exactly as the chmod numeric notation with a leading zero. Some examples: for chmod 777 (a=rwx), set to 0777 (octal) or 511 (base-10). For chmod 640 (u=rw,g=r), set to 0640 (octal) or 416 (base-10). For chmod 755 (u=rwx,g=rx,o=rx), set to 0755 (octal) or 493 (base-10). * This might be in conflict with other options that affect the file mode, like fsGroup, and the result can be other mode bits set.", "type": "integer", "format": "int32" }, "optional": { "description": "Not supported by Cloud Run.", "type": "boolean" } } }, "KeyToPath": { "id": "KeyToPath", "description": "Maps a string key to a path within a volume.", "type": "object", "properties": { "key": { "description": "The Cloud Secret Manager secret version. Can be 'latest' for the latest value, or an integer or a secret alias for a specific version. The key to project.", "type": "string" }, "path": { "description": "The relative path of the file to map the key to. May not be an absolute path. May not contain the path element '..'. May not start with the string '..'.", "type": "string" }, "mode": { "description": "(Optional) Mode bits to use on this file, must be a value between 01 and 0777 (octal). If 0 or not set, the Volume's default mode will be used. Notes * Internally, a umask of 0222 will be applied to any non-zero value. * This is an integer representation of the mode bits. So, the octal integer value should look exactly as the chmod numeric notation with a leading zero. Some examples: for chmod 777 (a=rwx), set to 0777 (octal) or 511 (base-10). For chmod 640 (u=rw,g=r), set to 0640 (octal) or 416 (base-10). For chmod 755 (u=rwx,g=rx,o=rx), set to 0755 (octal) or 493 (base-10). * This might be in conflict with other options that affect the file mode, like fsGroup, and the result can be other mode bits set.", "type": "integer", "format": "int32" } } }, "ConfigMapVolumeSource": { "id": "ConfigMapVolumeSource", "description": "Not supported by Cloud Run. Adapts a ConfigMap into a volume. The contents of the target ConfigMap's Data field will be presented in a volume as files using the keys in the Data field as the file names, unless the items element is populated with specific mappings of keys to paths.", "type": "object", "properties": { "name": { "description": "Name of the config.", "type": "string" }, "items": { "description": "(Optional) If unspecified, each key-value pair in the Data field of the referenced Secret will be projected into the volume as a file whose name is the key and content is the value. If specified, the listed keys will be projected into the specified paths, and unlisted keys will not be present. If a key is specified that is not present in the Secret, the volume setup will error unless it is marked optional.", "type": "array", "items": { "$ref": "KeyToPath" } }, "defaultMode": { "description": "(Optional) Integer representation of mode bits to use on created files by default. Must be a value between 01 and 0777 (octal). If 0 or not set, it will default to 0644. Directories within the path are not affected by this setting. Notes * Internally, a umask of 0222 will be applied to any non-zero value. * This is an integer representation of the mode bits. So, the octal integer value should look exactly as the chmod numeric notation with a leading zero. Some examples: for chmod 777 (a=rwx), set to 0777 (octal) or 511 (base-10). For chmod 640 (u=rw,g=r), set to 0640 (octal) or 416 (base-10). For chmod 755 (u=rwx,g=rx,o=rx), set to 0755 (octal) or 493 (base-10). * This might be in conflict with other options that affect the file mode, like fsGroup, and the result can be other mode bits set.", "type": "integer", "format": "int32" }, "optional": { "description": "(Optional) Specify whether the Secret or its keys must be defined.", "type": "boolean" } } }, "EmptyDirVolumeSource": { "id": "EmptyDirVolumeSource", "description": "In memory (tmpfs) ephemeral storage. It is ephemeral in the sense that when the sandbox is taken down, the data is destroyed with it (it does not persist across sandbox runs).", "type": "object", "properties": { "medium": { "description": "The medium on which the data is stored. The default is \"\" which means to use the node's default medium. Must be an empty string (default) or Memory. More info: https://kubernetes.io/docs/concepts/storage/volumes#emptydir", "type": "string" }, "sizeLimit": { "description": "Limit on the storage usable by this EmptyDir volume. The size limit is also applicable for memory medium. The maximum usage on memory medium EmptyDir would be the minimum value between the SizeLimit specified here and the sum of memory limits of all containers. The default is nil which means that the limit is undefined. More info: https://cloud.google.com/run/docs/configuring/in-memory-volumes#configure-volume. Info in Kubernetes: https://kubernetes.io/docs/concepts/storage/volumes/#emptydir", "type": "string" } } }, "NFSVolumeSource": { "id": "NFSVolumeSource", "description": "Represents a persistent volume that will be mounted using NFS. This volume will be shared between all instances of the resource and data will not be deleted when the instance is shut down.", "type": "object", "properties": { "server": { "description": "Hostname or IP address of the NFS server.", "type": "string" }, "path": { "description": "Path that is exported by the NFS server.", "type": "string" }, "readOnly": { "description": "If true, mount the NFS volume as read only. Defaults to false.", "type": "boolean" } } }, "CSIVolumeSource": { "id": "CSIVolumeSource", "description": "Storage volume source using the Container Storage Interface.", "type": "object", "properties": { "driver": { "description": "name of the CSI driver for the requested storage system. Cloud Run supports the following drivers: * gcsfuse.run.googleapis.com : Mount a Cloud Storage Bucket as a volume.", "type": "string" }, "readOnly": { "description": "If true, mount the volume as read only. Defaults to false.", "type": "boolean" }, "volumeAttributes": { "description": "stores driver specific attributes. For Google Cloud Storage volumes, the following attributes are supported: * bucketName: the name of the Cloud Storage bucket to mount. The Cloud Run Service identity must have access to this bucket.", "type": "object", "additionalProperties": { "type": "string" } } } }, "RevisionStatus": { "id": "RevisionStatus", "description": "RevisionStatus communicates the observed state of the Revision (from the controller).", "type": "object", "properties": { "observedGeneration": { "description": "ObservedGeneration is the 'Generation' of the Revision that was last processed by the controller. Clients polling for completed reconciliation should poll until observedGeneration = metadata.generation, and the Ready condition's status is True or False.", "type": "integer", "format": "int32" }, "conditions": { "description": "Conditions communicate information about ongoing/complete reconciliation processes that bring the \"spec\" inline with the observed state of the world. As a Revision is being prepared, it will incrementally update conditions. Revision-specific conditions include: * `ResourcesAvailable`: `True` when underlying resources have been provisioned. * `ContainerHealthy`: `True` when the Revision readiness check completes. * `Active`: `True` when the Revision may receive traffic.", "type": "array", "items": { "$ref": "GoogleCloudRunV1Condition" } }, "logUrl": { "description": "Optional. Specifies the generated logging url for this particular revision based on the revision url template specified in the controller's config.", "type": "string" }, "serviceName": { "description": "Not currently used by Cloud Run.", "type": "string" }, "imageDigest": { "description": "ImageDigest holds the resolved digest for the image specified within .Spec.Container.Image. The digest is resolved during the creation of Revision. This field holds the digest value regardless of whether a tag or digest was originally specified in the Container object.", "type": "string" }, "desiredReplicas": { "description": "Output only. The configured number of instances running this revision. For Cloud Run, this only includes instances provisioned using the minScale annotation. It does not include instances created by autoscaling.", "readOnly": true, "type": "integer", "format": "int32" } } }, "GoogleCloudRunV1Condition": { "id": "GoogleCloudRunV1Condition", "description": "Conditions show the status of reconciliation progress on a given resource. Most resource use a top-level condition type \"Ready\" or \"Completed\" to show overall status with other conditions to checkpoint each stage of reconciliation. Note that if metadata.Generation does not equal status.ObservedGeneration, the conditions shown may not be relevant for the current spec.", "type": "object", "properties": { "type": { "description": "type is used to communicate the status of the reconciliation process. Types common to all resources include: * \"Ready\" or \"Completed\": True when the Resource is ready.", "type": "string" }, "status": { "description": "Status of the condition, one of True, False, Unknown.", "type": "string" }, "reason": { "description": "Optional. One-word CamelCase reason for the condition's last transition. These are intended to be stable, unique values which the client may use to trigger error handling logic, whereas messages which may be changed later by the server.", "type": "string" }, "message": { "description": "Optional. Human readable message indicating details about the current status.", "type": "string" }, "lastTransitionTime": { "description": "Optional. Last time the condition transitioned from one status to another.", "type": "string", "format": "google-datetime" }, "severity": { "description": "Optional. How to interpret this condition. One of Error, Warning, or Info. Conditions of severity Info do not contribute to resource readiness.", "type": "string" } } }, "Status": { "id": "Status", "description": "Status is a return value for calls that don't return other objects.", "type": "object", "properties": { "metadata": { "description": "Standard list metadata.", "$ref": "ListMeta" }, "status": { "description": "Status of the operation. One of: \"Success\" or \"Failure\".", "type": "string" }, "message": { "description": "A human-readable description of the status of this operation.", "type": "string" }, "reason": { "description": "A machine-readable description of why this operation is in the \"Failure\" status. If this value is empty there is no information available. A Reason clarifies an HTTP status code but does not override it.", "type": "string" }, "details": { "description": "Extended data associated with the reason. Each reason may define its own extended details. This field is optional and the data returned is not guaranteed to conform to any schema except that defined by the reason type.", "$ref": "StatusDetails" }, "code": { "description": "Suggested HTTP return code for this status, 0 if not set.", "type": "integer", "format": "int32" } } }, "StatusDetails": { "id": "StatusDetails", "description": "StatusDetails is a set of additional properties that MAY be set by the server to provide additional information about a response. The Reason field of a Status object defines what attributes will be set. Clients must ignore fields that do not match the defined type of each attribute, and should assume that any attribute may be empty, invalid, or under defined.", "type": "object", "properties": { "name": { "description": "The name attribute of the resource associated with the status StatusReason (when there is a single name which can be described).", "type": "string" }, "group": { "description": "The group attribute of the resource associated with the status StatusReason.", "type": "string" }, "kind": { "description": "The kind attribute of the resource associated with the status StatusReason. On some operations may differ from the requested resource Kind.", "type": "string" }, "uid": { "description": "UID of the resource. (when there is a single resource which can be described).", "type": "string" }, "causes": { "description": "The Causes array includes more details associated with the StatusReason failure. Not all StatusReasons may provide detailed causes.", "type": "array", "items": { "$ref": "StatusCause" } }, "retryAfterSeconds": { "description": "If specified, the time in seconds before the operation should be retried. Some errors may indicate the client must take an alternate action - for those errors this field may indicate how long to wait before taking the alternate action.", "type": "integer", "format": "int32" } } }, "StatusCause": { "id": "StatusCause", "description": "StatusCause provides more information about an api.Status failure, including cases when multiple errors are encountered.", "type": "object", "properties": { "reason": { "description": "A machine-readable description of the cause of the error. If this value is empty there is no information available.", "type": "string" }, "message": { "description": "A human-readable description of the cause of the error. This field may be presented as-is to a reader.", "type": "string" }, "field": { "description": "The field of the resource that has caused this error, as named by its JSON serialization. May include dot and postfix notation for nested attributes. Arrays are zero-indexed. Fields may appear more than once in an array of causes due to fields having multiple errors. Examples: \"name\" - the field \"name\" on the current resource \"items[0].name\" - the field \"name\" on the first array entry in \"items\"", "type": "string" } } }, "ListConfigurationsResponse": { "id": "ListConfigurationsResponse", "description": "ListConfigurationsResponse is a list of Configuration resources.", "type": "object", "properties": { "apiVersion": { "description": "The API version for this call such as \"serving.knative.dev/v1\".", "type": "string" }, "kind": { "description": "The kind of this resource, in this case \"ConfigurationList\".", "type": "string" }, "metadata": { "description": "Metadata associated with this Configuration list.", "$ref": "ListMeta" }, "items": { "description": "List of Configurations.", "type": "array", "items": { "$ref": "Configuration" } }, "unreachable": { "description": "Locations that could not be reached.", "type": "array", "items": { "type": "string" } } } }, "Configuration": { "id": "Configuration", "description": "Configuration represents the \"floating HEAD\" of a linear history of Revisions, and optionally how the containers those revisions reference are built. Users create new Revisions by updating the Configuration's spec. The \"latest created\" revision's name is available under status, as is the \"latest ready\" revision's name.", "type": "object", "properties": { "apiVersion": { "description": "The API version for this call such as \"serving.knative.dev/v1\".", "type": "string" }, "kind": { "description": "The kind of resource, in this case always \"Configuration\".", "type": "string" }, "metadata": { "description": "Metadata associated with this Configuration, including name, namespace, labels, and annotations.", "$ref": "ObjectMeta" }, "spec": { "description": "Spec holds the desired state of the Configuration (from the client).", "$ref": "ConfigurationSpec" }, "status": { "description": "Status communicates the observed state of the Configuration (from the controller).", "$ref": "ConfigurationStatus" } } }, "ConfigurationSpec": { "id": "ConfigurationSpec", "description": "ConfigurationSpec holds the desired state of the Configuration (from the client).", "type": "object", "properties": { "template": { "description": "Template holds the latest specification for the Revision to be stamped out.", "$ref": "RevisionTemplate" } } }, "RevisionTemplate": { "id": "RevisionTemplate", "description": "RevisionTemplateSpec describes the data a revision should have when created from a template.", "type": "object", "properties": { "metadata": { "description": "Optional metadata for this Revision, including labels and annotations. Name will be generated by the Configuration. The following annotation keys set properties of the created revision: * `autoscaling.knative.dev/minScale` sets the minimum number of instances. * `autoscaling.knative.dev/maxScale` sets the maximum number of instances. * `run.googleapis.com/cloudsql-instances` sets Cloud SQL connections. Multiple values should be comma separated. * `run.googleapis.com/health-check-disabled`: if true, deploy-time startup probes will not run for this revision. * `run.googleapis.com/vpc-access-connector` sets a Serverless VPC Access connector. * `run.googleapis.com/vpc-access-egress` sets VPC egress. Supported values are `all-traffic`, `all` (deprecated), and `private-ranges-only`. `all-traffic` and `all` provide the same functionality. `all` is deprecated but will continue to be supported. Prefer `all-traffic`.", "$ref": "ObjectMeta" }, "spec": { "description": "RevisionSpec holds the desired state of the Revision (from the client).", "$ref": "RevisionSpec" } } }, "ConfigurationStatus": { "id": "ConfigurationStatus", "description": "ConfigurationStatus communicates the observed state of the Configuration (from the controller).", "type": "object", "properties": { "observedGeneration": { "description": "ObservedGeneration is the 'Generation' of the Configuration that was last processed by the controller. The observed generation is updated even if the controller failed to process the spec and create the Revision. Clients polling for completed reconciliation should poll until observedGeneration = metadata.generation, and the Ready condition's status is True or False.", "type": "integer", "format": "int32" }, "latestCreatedRevisionName": { "description": "LatestCreatedRevisionName is the last revision that was created from this Configuration. It might not be ready yet, so for the latest ready revision, use LatestReadyRevisionName.", "type": "string" }, "latestReadyRevisionName": { "description": "LatestReadyRevisionName holds the name of the latest Revision stamped out from this Configuration that has had its \"Ready\" condition become \"True\".", "type": "string" }, "conditions": { "description": "Conditions communicate information about ongoing/complete reconciliation processes that bring the \"spec\" inline with the observed state of the world.", "type": "array", "items": { "$ref": "GoogleCloudRunV1Condition" } } } }, "DomainMapping": { "id": "DomainMapping", "description": "Resource to hold the state and status of a user's domain mapping. NOTE: This resource is currently in Beta.", "type": "object", "properties": { "apiVersion": { "description": "The API version for this call such as \"domains.cloudrun.com/v1\".", "type": "string" }, "kind": { "description": "The kind of resource, in this case \"DomainMapping\".", "type": "string" }, "metadata": { "description": "Metadata associated with this BuildTemplate.", "$ref": "ObjectMeta" }, "spec": { "description": "The spec for this DomainMapping.", "$ref": "DomainMappingSpec" }, "status": { "description": "The current status of the DomainMapping.", "$ref": "DomainMappingStatus" } } }, "DomainMappingSpec": { "id": "DomainMappingSpec", "description": "The desired state of the Domain Mapping.", "type": "object", "properties": { "routeName": { "description": "The name of the Knative Route that this DomainMapping applies to. The route must exist.", "type": "string" }, "certificateMode": { "description": "The mode of the certificate.", "type": "string", "enumDescriptions": [ "", "Do not provision an HTTPS certificate.", "Automatically provisions an HTTPS certificate via GoogleCA." ], "enum": [ "CERTIFICATE_MODE_UNSPECIFIED", "NONE", "AUTOMATIC" ] }, "forceOverride": { "description": "If set, the mapping will override any mapping set before this spec was set. It is recommended that the user leaves this empty to receive an error warning about a potential conflict and only set it once the respective UI has given such a warning.", "type": "boolean" } } }, "DomainMappingStatus": { "id": "DomainMappingStatus", "description": "The current state of the Domain Mapping.", "type": "object", "properties": { "conditions": { "description": "Array of observed DomainMappingConditions, indicating the current state of the DomainMapping.", "type": "array", "items": { "$ref": "GoogleCloudRunV1Condition" } }, "observedGeneration": { "description": "ObservedGeneration is the 'Generation' of the DomainMapping that was last processed by the controller. Clients polling for completed reconciliation should poll until observedGeneration = metadata.generation and the Ready condition's status is True or False.", "type": "integer", "format": "int32" }, "resourceRecords": { "description": "The resource records required to configure this domain mapping. These records must be added to the domain's DNS configuration in order to serve the application via this domain mapping.", "type": "array", "items": { "$ref": "ResourceRecord" } }, "mappedRouteName": { "description": "The name of the route that the mapping currently points to.", "type": "string" }, "url": { "description": "Optional. Not supported by Cloud Run.", "type": "string" } } }, "ResourceRecord": { "id": "ResourceRecord", "description": "A DNS resource record.", "type": "object", "properties": { "name": { "description": "Relative name of the object affected by this record. Only applicable for `CNAME` records. Example: 'www'.", "type": "string" }, "rrdata": { "description": "Data for this record. Values vary by record type, as defined in RFC 1035 (section 5) and RFC 1034 (section 3.6.1).", "type": "string" }, "type": { "description": "Resource record type. Example: `AAAA`.", "type": "string", "enumDescriptions": [ "An unknown resource record.", "An A resource record. Data is an IPv4 address.", "An AAAA resource record. Data is an IPv6 address.", "A CNAME resource record. Data is a domain name to be aliased." ], "enum": [ "RECORD_TYPE_UNSPECIFIED", "A", "AAAA", "CNAME" ] } } }, "ListDomainMappingsResponse": { "id": "ListDomainMappingsResponse", "description": "ListDomainMappingsResponse is a list of DomainMapping resources.", "type": "object", "properties": { "apiVersion": { "description": "The API version for this call such as \"domains.cloudrun.com/v1\".", "type": "string" }, "kind": { "description": "The kind of this resource, in this case \"DomainMappingList\".", "type": "string" }, "metadata": { "description": "Metadata associated with this DomainMapping list.", "$ref": "ListMeta" }, "items": { "description": "List of DomainMappings.", "type": "array", "items": { "$ref": "DomainMapping" } }, "unreachable": { "description": "Locations that could not be reached.", "type": "array", "items": { "type": "string" } } } }, "Task": { "id": "Task", "description": "Task represents a single run of a container to completion.", "type": "object", "properties": { "apiVersion": { "description": "Optional. APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values.", "type": "string" }, "kind": { "description": "Optional. Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase.", "type": "string" }, "metadata": { "description": "Optional. Standard object's metadata.", "$ref": "ObjectMeta" }, "spec": { "description": "Optional. Specification of the desired behavior of a task.", "$ref": "TaskSpec" }, "status": { "description": "Output only. Current status of a task.", "readOnly": true, "$ref": "TaskStatus" } } }, "TaskSpec": { "id": "TaskSpec", "description": "TaskSpec is a description of a task.", "type": "object", "properties": { "volumes": { "description": "Optional. List of volumes that can be mounted by containers belonging to the task.", "type": "array", "items": { "$ref": "Volume" } }, "containers": { "description": "Optional. List of containers belonging to the task. We disallow a number of fields on this Container.", "type": "array", "items": { "$ref": "Container" } }, "maxRetries": { "description": "Optional. Number of retries allowed per task, before marking this job failed. Defaults to 3.", "type": "integer", "format": "int32" }, "timeoutSeconds": { "description": "Optional. Duration in seconds the task may be active before the system will actively try to mark it failed and kill associated containers. This applies per attempt of a task, meaning each retry can run for the full timeout. Defaults to 600 seconds.", "type": "string", "format": "int64" }, "serviceAccountName": { "description": "Optional. Email address of the IAM service account associated with the task of a job execution. The service account represents the identity of the running task, and determines what permissions the task has. If not provided, the task will use the project's default service account.", "type": "string" } } }, "TaskStatus": { "id": "TaskStatus", "description": "TaskStatus represents the status of a task.", "type": "object", "properties": { "observedGeneration": { "description": "Optional. The 'generation' of the task that was last processed by the controller.", "type": "integer", "format": "int32" }, "conditions": { "description": "Optional. Conditions communicate information about ongoing/complete reconciliation processes that bring the \"spec\" inline with the observed state of the world. Task-specific conditions include: * `Started`: `True` when the task has started to execute. * `Completed`: `True` when the task has succeeded. `False` when the task has failed.", "type": "array", "items": { "$ref": "GoogleCloudRunV1Condition" } }, "index": { "description": "Required. Index of the task, unique per execution, and beginning at 0.", "type": "integer", "format": "int32" }, "startTime": { "description": "Optional. Represents time when the task started to run. It is not guaranteed to be set in happens-before order across separate operations. It is represented in RFC3339 form and is in UTC.", "type": "string", "format": "google-datetime" }, "completionTime": { "description": "Optional. Represents time when the task was completed. It is not guaranteed to be set in happens-before order across separate operations. It is represented in RFC3339 form and is in UTC.", "type": "string", "format": "google-datetime" }, "retried": { "description": "Optional. The number of times this task was retried. Instances are retried when they fail up to the maxRetries limit.", "type": "integer", "format": "int32" }, "lastAttemptResult": { "description": "Optional. Result of the last attempt of this task.", "$ref": "TaskAttemptResult" }, "logUri": { "description": "Optional. URI where logs for this task can be found in Cloud Console.", "type": "string" } } }, "TaskAttemptResult": { "id": "TaskAttemptResult", "description": "Result of a task attempt.", "type": "object", "properties": { "status": { "description": "Optional. The status of this attempt. If the status code is OK, then the attempt succeeded.", "$ref": "GoogleRpcStatus" }, "exitCode": { "description": "Optional. The exit code of this attempt. This may be unset if the container was unable to exit cleanly with a code due to some other failure. See status field for possible failure details.", "type": "integer", "format": "int32" } } }, "ListTasksResponse": { "id": "ListTasksResponse", "description": "ListTasksResponse is a list of Tasks resources.", "type": "object", "properties": { "items": { "description": "List of Tasks.", "type": "array", "items": { "$ref": "Task" } }, "apiVersion": { "description": "The API version for this call such as \"run.googleapis.com/v1\".", "type": "string" }, "kind": { "description": "The kind of this resource, in this case \"TasksList\".", "type": "string" }, "metadata": { "description": "Metadata associated with this tasks list.", "$ref": "ListMeta" }, "unreachable": { "description": "Locations that could not be reached.", "type": "array", "items": { "type": "string" } } } }, "Execution": { "id": "Execution", "description": "Execution represents the configuration of a single execution. An execution is an immutable resource that references a container image which is run to completion.", "type": "object", "properties": { "apiVersion": { "description": "Optional. APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values.", "type": "string" }, "kind": { "description": "Optional. Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase.", "type": "string" }, "metadata": { "description": "Optional. Standard object's metadata.", "$ref": "ObjectMeta" }, "spec": { "description": "Optional. Specification of the desired behavior of an execution.", "$ref": "ExecutionSpec" }, "status": { "description": "Output only. Current status of an execution.", "readOnly": true, "$ref": "ExecutionStatus" } } }, "ExecutionSpec": { "id": "ExecutionSpec", "description": "ExecutionSpec describes how the execution will look.", "type": "object", "properties": { "parallelism": { "description": "Optional. Specifies the maximum desired number of tasks the execution should run at given time. Must be \u003c= task_count. When the job is run, if this field is 0 or unset, the maximum possible value will be used for that execution. The actual number of tasks running in steady state will be less than this number when there are fewer tasks waiting to be completed, i.e. when the work left to do is less than max parallelism.", "type": "integer", "format": "int32" }, "taskCount": { "description": "Optional. Specifies the desired number of tasks the execution should run. Setting to 1 means that parallelism is limited to 1 and the success of that task signals the success of the execution. Defaults to 1.", "type": "integer", "format": "int32" }, "template": { "description": "Optional. The template used to create tasks for this execution.", "$ref": "TaskTemplateSpec" } } }, "TaskTemplateSpec": { "id": "TaskTemplateSpec", "description": "TaskTemplateSpec describes the data a task should have when created from a template.", "type": "object", "properties": { "spec": { "description": "Optional. Specification of the desired behavior of the task.", "$ref": "TaskSpec" } } }, "ExecutionStatus": { "id": "ExecutionStatus", "description": "ExecutionStatus represents the current state of an Execution.", "type": "object", "properties": { "observedGeneration": { "description": "Optional. The 'generation' of the execution that was last processed by the controller.", "type": "integer", "format": "int32" }, "conditions": { "description": "Optional. Conditions communicate information about ongoing/complete reconciliation processes that bring the \"spec\" inline with the observed state of the world. Execution-specific conditions include: * `ResourcesAvailable`: `True` when underlying resources have been provisioned. * `Started`: `True` when the execution has started to execute. * `Completed`: `True` when the execution has succeeded. `False` when the execution has failed.", "type": "array", "items": { "$ref": "GoogleCloudRunV1Condition" } }, "startTime": { "description": "Optional. Represents the time that the execution started to run. It is not guaranteed to be set in happens-before order across separate operations. It is represented in RFC3339 form and is in UTC.", "type": "string", "format": "google-datetime" }, "completionTime": { "description": "Optional. Represents the time that the execution was completed. It is not guaranteed to be set in happens-before order across separate operations. It is represented in RFC3339 form and is in UTC. +optional", "type": "string", "format": "google-datetime" }, "runningCount": { "description": "Optional. The number of actively running tasks.", "type": "integer", "format": "int32" }, "succeededCount": { "description": "Optional. The number of tasks which reached phase Succeeded.", "type": "integer", "format": "int32" }, "failedCount": { "description": "Optional. The number of tasks which reached phase Failed.", "type": "integer", "format": "int32" }, "cancelledCount": { "description": "Optional. The number of tasks which reached phase Cancelled.", "type": "integer", "format": "int32" }, "retriedCount": { "description": "Optional. The number of tasks which have retried at least once.", "type": "integer", "format": "int32" }, "logUri": { "description": "Optional. URI where logs for this execution can be found in Cloud Console.", "type": "string" } } }, "ListExecutionsResponse": { "id": "ListExecutionsResponse", "description": "ListExecutionsResponse is a list of Executions resources.", "type": "object", "properties": { "items": { "description": "List of Executions.", "type": "array", "items": { "$ref": "Execution" } }, "apiVersion": { "description": "The API version for this call such as \"run.googleapis.com/v1\".", "type": "string" }, "kind": { "description": "The kind of this resource, in this case \"ExecutionsList\".", "type": "string" }, "metadata": { "description": "Metadata associated with this executions list.", "$ref": "ListMeta" }, "unreachable": { "description": "Locations that could not be reached.", "type": "array", "items": { "type": "string" } } } }, "CancelExecutionRequest": { "id": "CancelExecutionRequest", "description": "Request message for cancelling an execution.", "type": "object", "properties": {} }, "Job": { "id": "Job", "description": "Job represents the configuration of a single job, which references a container image which is run to completion.", "type": "object", "properties": { "apiVersion": { "description": "Optional. APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values.", "type": "string" }, "kind": { "description": "Optional. Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase.", "type": "string" }, "metadata": { "description": "Optional. Standard object's metadata.", "$ref": "ObjectMeta" }, "spec": { "description": "Optional. Specification of the desired behavior of a job.", "$ref": "JobSpec" }, "status": { "description": "Output only. Current status of a job.", "readOnly": true, "$ref": "JobStatus" } } }, "JobSpec": { "id": "JobSpec", "description": "JobSpec describes how the job will look.", "type": "object", "properties": { "template": { "description": "Optional. Describes the execution that will be created when running a job.", "$ref": "ExecutionTemplateSpec" }, "startExecutionToken": { "description": "A unique string used as a suffix for creating a new execution. The Job will become ready when the execution is successfully started. The sum of job name and token length must be fewer than 63 characters.", "type": "string" }, "runExecutionToken": { "description": "A unique string used as a suffix for creating a new execution. The Job will become ready when the execution is successfully completed. The sum of job name and token length must be fewer than 63 characters.", "type": "string" } } }, "ExecutionTemplateSpec": { "id": "ExecutionTemplateSpec", "description": "ExecutionTemplateSpec describes the metadata and spec an Execution should have when created from a job.", "type": "object", "properties": { "metadata": { "description": "Optional. Optional metadata for this Execution, including labels and annotations. The following annotation keys set properties of the created execution: * `run.googleapis.com/cloudsql-instances` sets Cloud SQL connections. Multiple values should be comma separated. * `run.googleapis.com/vpc-access-connector` sets a Serverless VPC Access connector. * `run.googleapis.com/vpc-access-egress` sets VPC egress. Supported values are `all-traffic`, `all` (deprecated), and `private-ranges-only`. `all-traffic` and `all` provide the same functionality. `all` is deprecated but will continue to be supported. Prefer `all-traffic`.", "$ref": "ObjectMeta" }, "spec": { "description": "Required. ExecutionSpec holds the desired configuration for executions of this job.", "$ref": "ExecutionSpec" } } }, "JobStatus": { "id": "JobStatus", "description": "JobStatus represents the current state of a Job.", "type": "object", "properties": { "observedGeneration": { "description": "The 'generation' of the job that was last processed by the controller.", "type": "integer", "format": "int32" }, "conditions": { "description": "Conditions communicate information about ongoing/complete reconciliation processes that bring the \"spec\" inline with the observed state of the world. Job-specific conditions include: * `Ready`: `True` when the job is ready to be executed.", "type": "array", "items": { "$ref": "GoogleCloudRunV1Condition" } }, "executionCount": { "description": "Number of executions created for this job.", "type": "integer", "format": "int32" }, "latestCreatedExecution": { "description": "A pointer to the most recently created execution for this job. This is set regardless of the eventual state of the execution.", "$ref": "ExecutionReference" } } }, "ExecutionReference": { "id": "ExecutionReference", "description": "Reference to an Execution. Use /Executions.GetExecution with the given name to get full execution including the latest status.", "type": "object", "properties": { "name": { "description": "Optional. Name of the execution.", "type": "string" }, "creationTimestamp": { "description": "Optional. Creation timestamp of the execution.", "type": "string", "format": "google-datetime" }, "completionTimestamp": { "description": "Optional. Completion timestamp of the execution.", "type": "string", "format": "google-datetime" }, "deletionTimestamp": { "description": "Optional. The read-only soft deletion timestamp of the execution.", "type": "string", "format": "google-datetime" }, "completionStatus": { "description": "Optional. Status for the execution completion.", "type": "string", "enumDescriptions": [ "The default value. This value is used if the state is omitted.", "Job execution has succeeded.", "Job execution has failed.", "Job execution is running normally.", "Waiting for backing resources to be provisioned.", "Job execution has been cancelled by the user." ], "enum": [ "COMPLETION_STATUS_UNSPECIFIED", "EXECUTION_SUCCEEDED", "EXECUTION_FAILED", "EXECUTION_RUNNING", "EXECUTION_PENDING", "EXECUTION_CANCELLED" ] } } }, "ListJobsResponse": { "id": "ListJobsResponse", "description": "ListJobsResponse is a list of Jobs resources.", "type": "object", "properties": { "items": { "description": "List of Jobs.", "type": "array", "items": { "$ref": "Job" } }, "apiVersion": { "description": "The API version for this call such as \"run.googleapis.com/v1\".", "type": "string" }, "kind": { "description": "The kind of this resource, in this case \"JobsList\".", "type": "string" }, "metadata": { "description": "Metadata associated with this jobs list.", "$ref": "ListMeta" }, "unreachable": { "description": "Locations that could not be reached.", "type": "array", "items": { "type": "string" } } } }, "Policy": { "id": "Policy", "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:[email protected]\", \"group:[email protected]\", \"domain:google.com\", \"serviceAccount:[email protected]\" ] }, { \"role\": \"roles/resourcemanager.organizationViewer\", \"members\": [ \"user:[email protected]\" ], \"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:[email protected] - group:[email protected] - domain:google.com - serviceAccount:[email protected] role: roles/resourcemanager.organizationAdmin - members: - user:[email protected] role: roles/resourcemanager.organizationViewer condition: title: expirable access description: Does not grant access after Sep 2020 expression: request.time \u003c timestamp('2020-10-01T00:00:00.000Z') etag: BwWWja0YfJA= version: 3 ``` For a description of IAM and its features, see the [IAM documentation](https://cloud.google.com/iam/docs/).", "type": "object", "properties": { "version": { "description": "Specifies the format of the policy. Valid values are `0`, `1`, and `3`. Requests that specify an invalid value are rejected. Any operation that affects conditional role bindings must specify version `3`. This requirement applies to the following operations: * Getting a policy that includes a conditional role binding * Adding a conditional role binding to a policy * Changing a conditional role binding in a policy * Removing any role binding, with or without a condition, from a policy that includes conditions **Important:** If you use IAM Conditions, you must include the `etag` field whenever you call `setIamPolicy`. If you omit this field, then IAM allows you to overwrite a version `3` policy with a version `1` policy, and all of the conditions in the version `3` policy are lost. If a policy does not include any conditions, operations on that policy may specify any valid version or leave the field unset. To learn which resources support conditions in their IAM policies, see the [IAM documentation](https://cloud.google.com/iam/help/conditions/resource-policies).", "type": "integer", "format": "int32" }, "bindings": { "description": "Associates a list of `members`, or principals, with a `role`. Optionally, may specify a `condition` that determines how and when the `bindings` are applied. Each of the `bindings` must contain at least one principal. The `bindings` in a `Policy` can refer to up to 1,500 principals; up to 250 of these principals can be Google groups. Each occurrence of a principal counts towards these limits. For example, if the `bindings` grant 50 different roles to `user:[email protected]`, and not to any other principal, then you can add another 1,450 principals to the `bindings` in the `Policy`.", "type": "array", "items": { "$ref": "Binding" } }, "auditConfigs": { "description": "Specifies cloud audit logging configuration for this policy.", "type": "array", "items": { "$ref": "AuditConfig" } }, "etag": { "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.", "type": "string", "format": "byte" } } }, "Binding": { "id": "Binding", "description": "Associates `members`, or principals, with a `role`.", "type": "object", "properties": { "role": { "description": "Role that is assigned to the list of `members`, or principals. For example, `roles/viewer`, `roles/editor`, or `roles/owner`. For an overview of the IAM roles and permissions, see the [IAM documentation](https://cloud.google.com/iam/docs/roles-overview). For a list of the available pre-defined roles, see [here](https://cloud.google.com/iam/docs/understanding-roles).", "type": "string" }, "members": { "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, `[email protected]` . * `serviceAccount:{emailid}`: An email address that represents a Google service account. For example, `[email protected]`. * `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, `[email protected]`. * `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, `[email protected]?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, `[email protected]?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, `[email protected]?uid=123456789012345678901`. If the group is recovered, this value reverts to `group:{emailid}` and the recovered group retains the role in the binding. * `deleted:principal://iam.googleapis.com/locations/global/workforcePools/{pool_id}/subject/{subject_attribute_value}`: Deleted single identity in a workforce identity pool. For example, `deleted:principal://iam.googleapis.com/locations/global/workforcePools/my-pool-id/subject/my-subject-attribute-value`.", "type": "array", "items": { "type": "string" } }, "condition": { "description": "The condition that is associated with this binding. If the condition evaluates to `true`, then this binding applies to the current request. If the condition evaluates to `false`, then this binding does not apply to the current request. However, a different role binding might grant the same role to one or more of the principals in this binding. To learn which resources support conditions in their IAM policies, see the [IAM documentation](https://cloud.google.com/iam/help/conditions/resource-policies).", "$ref": "Expr" } } }, "Expr": { "id": "Expr", "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.", "type": "object", "properties": { "expression": { "description": "Textual representation of an expression in Common Expression Language syntax.", "type": "string" }, "title": { "description": "Optional. Title for the expression, i.e. a short string describing its purpose. This can be used e.g. in UIs which allow to enter the expression.", "type": "string" }, "description": { "description": "Optional. Description of the expression. This is a longer text which describes the expression, e.g. when hovered over it in a UI.", "type": "string" }, "location": { "description": "Optional. String indicating the location of the expression for error reporting, e.g. a file name and a position in the file.", "type": "string" } } }, "AuditConfig": { "id": "AuditConfig", "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:[email protected]\" ] }, { \"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:[email protected]\" ] } ] } ] } For sampleservice, this policy enables DATA_READ, DATA_WRITE and ADMIN_READ logging. It also exempts `[email protected]` from DATA_READ logging, and `[email protected]` from DATA_WRITE logging.", "type": "object", "properties": { "service": { "description": "Specifies a service that will be enabled for audit logging. For example, `storage.googleapis.com`, `cloudsql.googleapis.com`. `allServices` is a special value that covers all services.", "type": "string" }, "auditLogConfigs": { "description": "The configuration for logging of each type of permission.", "type": "array", "items": { "$ref": "AuditLogConfig" } } } }, "AuditLogConfig": { "id": "AuditLogConfig", "description": "Provides the configuration for logging a type of permissions. Example: { \"audit_log_configs\": [ { \"log_type\": \"DATA_READ\", \"exempted_members\": [ \"user:[email protected]\" ] }, { \"log_type\": \"DATA_WRITE\" } ] } This enables 'DATA_READ' and 'DATA_WRITE' logging, while exempting [email protected] from DATA_READ logging.", "type": "object", "properties": { "logType": { "description": "The log type that this config enables.", "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" ], "enum": [ "LOG_TYPE_UNSPECIFIED", "ADMIN_READ", "DATA_WRITE", "DATA_READ" ] }, "exemptedMembers": { "description": "Specifies the identities that do not cause logging for this type of permission. Follows the same format of Binding.members.", "type": "array", "items": { "type": "string" } } } }, "SetIamPolicyRequest": { "id": "SetIamPolicyRequest", "description": "Request message for `SetIamPolicy` method.", "type": "object", "properties": { "policy": { "description": "REQUIRED: The complete policy to be applied to the `resource`. The size of the policy is limited to a few 10s of KB. An empty policy is a valid policy but certain Google Cloud services (such as Projects) might reject them.", "$ref": "Policy" }, "updateMask": { "description": "OPTIONAL: A FieldMask specifying which fields of the policy to modify. Only the fields in the mask will be modified. If no mask is provided, the following default mask is used: `paths: \"bindings, etag\"`", "type": "string", "format": "google-fieldmask" } } }, "TestIamPermissionsRequest": { "id": "TestIamPermissionsRequest", "description": "Request message for `TestIamPermissions` method.", "type": "object", "properties": { "permissions": { "description": "The set of permissions to check for the `resource`. Permissions with wildcards (such as `*` or `storage.*`) are not allowed. For more information see [IAM Overview](https://cloud.google.com/iam/docs/overview#permissions).", "type": "array", "items": { "type": "string" } } } }, "TestIamPermissionsResponse": { "id": "TestIamPermissionsResponse", "description": "Response message for `TestIamPermissions` method.", "type": "object", "properties": { "permissions": { "description": "A subset of `TestPermissionsRequest.permissions` that the caller is allowed.", "type": "array", "items": { "type": "string" } } } }, "RunJobRequest": { "id": "RunJobRequest", "description": "Request message for creating a new execution of a job.", "type": "object", "properties": { "overrides": { "description": "Optional. Overrides existing job configuration for one specific new job execution only, using the specified values to update the job configuration for the new execution.", "$ref": "Overrides" } } }, "Overrides": { "id": "Overrides", "description": "RunJob Overrides that contains Execution fields to be overridden on the go.", "type": "object", "properties": { "containerOverrides": { "description": "Per container override specification.", "type": "array", "items": { "$ref": "ContainerOverride" } }, "taskCount": { "description": "The desired number of tasks the execution should run. Will replace existing task_count value.", "type": "integer", "format": "int32" }, "timeoutSeconds": { "description": "Duration in seconds the task may be active before the system will actively try to mark it failed and kill associated containers. Will replace existing timeout_seconds value.", "type": "integer", "format": "int32" } } }, "ContainerOverride": { "id": "ContainerOverride", "description": "Per container override specification.", "type": "object", "properties": { "name": { "description": "The name of the container specified as a DNS_LABEL.", "type": "string" }, "args": { "description": "Arguments to the entrypoint. The specified arguments replace and override any existing entrypoint arguments. Must be empty if `clear_args` is set to true.", "type": "array", "items": { "type": "string" } }, "env": { "description": "List of environment variables to set in the container. All specified environment variables are merged with existing environment variables. When the specified environment variables exist, these values override any existing values.", "type": "array", "items": { "$ref": "EnvVar" } }, "clearArgs": { "description": "Optional. Set to True to clear all existing arguments.", "type": "boolean" } } }, "ListRoutesResponse": { "id": "ListRoutesResponse", "description": "ListRoutesResponse is a list of Route resources.", "type": "object", "properties": { "apiVersion": { "description": "The API version for this call such as \"serving.knative.dev/v1\".", "type": "string" }, "kind": { "description": "The kind of this resource, in this case always \"RouteList\".", "type": "string" }, "metadata": { "description": "Metadata associated with this Route list.", "$ref": "ListMeta" }, "items": { "description": "List of Routes.", "type": "array", "items": { "$ref": "Route" } }, "unreachable": { "description": "Locations that could not be reached.", "type": "array", "items": { "type": "string" } } } }, "Route": { "id": "Route", "description": "Route is responsible for configuring ingress over a collection of Revisions. Some of the Revisions a Route distributes traffic over may be specified by referencing the Configuration responsible for creating them; in these cases the Route is additionally responsible for monitoring the Configuration for \"latest ready\" revision changes, and smoothly rolling out latest revisions. Cloud Run currently supports referencing a single Configuration to automatically deploy the \"latest ready\" Revision from that Configuration.", "type": "object", "properties": { "apiVersion": { "description": "The API version for this call such as \"serving.knative.dev/v1\".", "type": "string" }, "kind": { "description": "The kind of this resource, in this case always \"Route\".", "type": "string" }, "metadata": { "description": "Metadata associated with this Route, including name, namespace, labels, and annotations.", "$ref": "ObjectMeta" }, "spec": { "description": "Spec holds the desired state of the Route (from the client).", "$ref": "RouteSpec" }, "status": { "description": "Status communicates the observed state of the Route (from the controller).", "$ref": "RouteStatus" } } }, "RouteSpec": { "id": "RouteSpec", "description": "RouteSpec holds the desired state of the Route (from the client).", "type": "object", "properties": { "traffic": { "description": "Traffic specifies how to distribute traffic over a collection of Knative Revisions and Configurations. Cloud Run currently supports a single configurationName.", "type": "array", "items": { "$ref": "TrafficTarget" } } } }, "TrafficTarget": { "id": "TrafficTarget", "description": "TrafficTarget holds a single entry of the routing table for a Route.", "type": "object", "properties": { "configurationName": { "description": "[Deprecated] Not supported in Cloud Run. It must be empty.", "deprecated": true, "type": "string" }, "revisionName": { "description": "Points this traffic target to a specific Revision. This field is mutually exclusive with latest_revision.", "type": "string" }, "percent": { "description": "Percent specifies percent of the traffic to this Revision or Configuration. This defaults to zero if unspecified.", "type": "integer", "format": "int32" }, "tag": { "description": "Tag is used to expose a dedicated url for referencing this target exclusively.", "type": "string" }, "latestRevision": { "description": "Uses the \"status.latestReadyRevisionName\" of the Service to determine the traffic target. When it changes, traffic will automatically migrate from the prior \"latest ready\" revision to the new one. This field must be false if RevisionName is set. This field defaults to true otherwise. If the field is set to true on Status, this means that the Revision was resolved from the Service's latest ready revision.", "type": "boolean" }, "url": { "description": "Output only. URL displays the URL for accessing tagged traffic targets. URL is displayed in status, and is disallowed on spec. URL must contain a scheme (e.g. https://) and a hostname, but may not contain anything else (e.g. basic auth, url path, etc.)", "readOnly": true, "type": "string" } } }, "RouteStatus": { "id": "RouteStatus", "description": "RouteStatus communicates the observed state of the Route (from the controller).", "type": "object", "properties": { "observedGeneration": { "description": "ObservedGeneration is the 'Generation' of the Route that was last processed by the controller. Clients polling for completed reconciliation should poll until observedGeneration = metadata.generation and the Ready condition's status is True or False. Note that providing a TrafficTarget that has latest_revision=True will result in a Route that does not increment either its metadata.generation or its observedGeneration, as new \"latest ready\" revisions from the Configuration are processed without an update to the Route's spec.", "type": "integer", "format": "int32" }, "conditions": { "description": "Conditions communicates information about ongoing/complete reconciliation processes that bring the \"spec\" inline with the observed state of the world.", "type": "array", "items": { "$ref": "GoogleCloudRunV1Condition" } }, "traffic": { "description": "Traffic holds the configured traffic distribution. These entries will always contain RevisionName references. When ConfigurationName appears in the spec, this will hold the LatestReadyRevisionName that was last observed.", "type": "array", "items": { "$ref": "TrafficTarget" } }, "url": { "description": "URL holds the url that will distribute traffic over the provided traffic targets. It generally has the form: `https://{route-hash}-{project-hash}-{cluster-level-suffix}.a.run.app`", "type": "string" }, "address": { "description": "Similar to url, information on where the service is available on HTTP.", "$ref": "Addressable" } } }, "Addressable": { "id": "Addressable", "description": "Information for connecting over HTTP(s).", "type": "object", "properties": { "url": { "type": "string" } } }, "ListServicesResponse": { "id": "ListServicesResponse", "description": "A list of Service resources.", "type": "object", "properties": { "apiVersion": { "description": "The API version for this call; returns \"serving.knative.dev/v1\".", "type": "string" }, "kind": { "description": "The kind of this resource; returns \"ServiceList\".", "type": "string" }, "metadata": { "description": "Metadata associated with this Service list.", "$ref": "ListMeta" }, "items": { "description": "List of Services.", "type": "array", "items": { "$ref": "Service" } }, "unreachable": { "description": "For calls against the global endpoint, returns the list of Cloud locations that could not be reached. For regional calls, this field is not used.", "type": "array", "items": { "type": "string" } } } }, "Service": { "id": "Service", "description": "Service acts as a top-level container that manages a set of Routes and Configurations which implement a network service. Service exists to provide a singular abstraction which can be access controlled, reasoned about, and which encapsulates software lifecycle decisions such as rollout policy and team resource ownership. Service acts only as an orchestrator of the underlying Routes and Configurations (much as a kubernetes Deployment orchestrates ReplicaSets). The Service's controller will track the statuses of its owned Configuration and Route, reflecting their statuses and conditions as its own.", "type": "object", "properties": { "apiVersion": { "description": "The API version for this call. It must be \"serving.knative.dev/v1\".", "type": "string" }, "kind": { "description": "The kind of resource. It must be \"Service\".", "type": "string" }, "metadata": { "description": "Metadata associated with this Service, including name, namespace, labels, and annotations. In Cloud Run, annotations with 'run.googleapis.com/' and 'autoscaling.knative.dev' are restricted, and the accepted annotations will be different depending on the resource type. The following Cloud Run-specific annotations are accepted in Service.metadata.annotations. * `run.googleapis.com/binary-authorization-breakglass` * `run.googleapis.com/binary-authorization` * `run.googleapis.com/client-name` * `run.googleapis.com/custom-audiences` * `run.googleapis.com/default-url-disabled` * `run.googleapis.com/description` * `run.googleapis.com/gc-traffic-tags` * `run.googleapis.com/ingress` * `run.googleapis.com/ingress` sets the ingress settings for the Service. See [the ingress settings documentation](/run/docs/securing/ingress) for details on configuring ingress settings. * `run.googleapis.com/ingress-status` is output-only and contains the currently active ingress settings for the Service. `run.googleapis.com/ingress-status` may differ from `run.googleapis.com/ingress` while the system is processing a change to `run.googleapis.com/ingress` or if the system failed to process a change to `run.googleapis.com/ingress`. When the system has processed all changes successfully `run.googleapis.com/ingress-status` and `run.googleapis.com/ingress` are equal.", "$ref": "ObjectMeta" }, "spec": { "description": "Holds the desired state of the Service (from the client).", "$ref": "ServiceSpec" }, "status": { "description": "Communicates the system-controlled state of the Service.", "$ref": "ServiceStatus" } } }, "ServiceSpec": { "id": "ServiceSpec", "description": "ServiceSpec holds the desired state of the Route (from the client), which is used to manipulate the underlying Route and Configuration(s).", "type": "object", "properties": { "template": { "description": "Holds the latest specification for the Revision to be stamped out.", "$ref": "RevisionTemplate" }, "traffic": { "description": "Specifies how to distribute traffic over a collection of Knative Revisions and Configurations to the Service's main URL.", "type": "array", "items": { "$ref": "TrafficTarget" } } } }, "ServiceStatus": { "id": "ServiceStatus", "description": "The current state of the Service. Output only.", "type": "object", "properties": { "observedGeneration": { "description": "Returns the generation last seen by the system. Clients polling for completed reconciliation should poll until observedGeneration = metadata.generation and the Ready condition's status is True or False.", "type": "integer", "format": "int32" }, "conditions": { "description": "Conditions communicate information about ongoing/complete reconciliation processes that bring the `spec` inline with the observed state of the world. Service-specific conditions include: * `ConfigurationsReady`: `True` when the underlying Configuration is ready. * `RoutesReady`: `True` when the underlying Route is ready. * `Ready`: `True` when all underlying resources are ready.", "type": "array", "items": { "$ref": "GoogleCloudRunV1Condition" } }, "latestReadyRevisionName": { "description": "Name of the latest Revision from this Service's Configuration that has had its `Ready` condition become `True`.", "type": "string" }, "latestCreatedRevisionName": { "description": "Name of the last revision that was created from this Service's Configuration. It might not be ready yet, for that use LatestReadyRevisionName.", "type": "string" }, "traffic": { "description": "Holds the configured traffic distribution. These entries will always contain RevisionName references. When ConfigurationName appears in the spec, this will hold the LatestReadyRevisionName that we last observed.", "type": "array", "items": { "$ref": "TrafficTarget" } }, "url": { "description": "URL that will distribute traffic over the provided traffic targets. It generally has the form `https://{route-hash}-{project-hash}-{cluster-level-suffix}.a.run.app`", "type": "string" }, "address": { "description": "Similar to url, information on where the service is available on HTTP.", "$ref": "Addressable" } } }, "GoogleDevtoolsCloudbuildV1BuildOperationMetadata": { "id": "GoogleDevtoolsCloudbuildV1BuildOperationMetadata", "description": "Metadata for build operations.", "type": "object", "properties": { "build": { "description": "The build that the operation is tracking.", "$ref": "GoogleDevtoolsCloudbuildV1Build" } } }, "GoogleDevtoolsCloudbuildV1Build": { "id": "GoogleDevtoolsCloudbuildV1Build", "description": "A build resource in the Cloud Build API. At a high level, a `Build` describes where to find source code, how to build it (for example, the builder image to run on the source), and where to store the built artifacts. Fields can include the following variables, which will be expanded when the build is created: - $PROJECT_ID: the project ID of the build. - $PROJECT_NUMBER: the project number of the build. - $LOCATION: the location/region of the build. - $BUILD_ID: the autogenerated ID of the build. - $REPO_NAME: the source repository name specified by RepoSource. - $BRANCH_NAME: the branch name specified by RepoSource. - $TAG_NAME: the tag name specified by RepoSource. - $REVISION_ID or $COMMIT_SHA: the commit SHA specified by RepoSource or resolved from the specified branch or tag. - $SHORT_SHA: first 7 characters of $REVISION_ID or $COMMIT_SHA.", "type": "object", "properties": { "name": { "description": "Output only. The 'Build' name with format: `projects/{project}/locations/{location}/builds/{build}`, where {build} is a unique identifier generated by the service.", "readOnly": true, "type": "string" }, "id": { "description": "Output only. Unique identifier of the build.", "readOnly": true, "type": "string" }, "projectId": { "description": "Output only. ID of the project.", "readOnly": true, "type": "string" }, "status": { "description": "Output only. Status of the build.", "readOnly": true, "type": "string", "enumDescriptions": [ "Status of the build is unknown.", "Build has been created and is pending execution and queuing. It has not been queued.", "Build or step is queued; work has not yet begun.", "Build or step is being executed.", "Build or step finished successfully.", "Build or step failed to complete successfully.", "Build or step failed due to an internal cause.", "Build or step took longer than was allowed.", "Build or step was canceled by a user.", "Build was enqueued for longer than the value of `queue_ttl`." ], "enum": [ "STATUS_UNKNOWN", "PENDING", "QUEUED", "WORKING", "SUCCESS", "FAILURE", "INTERNAL_ERROR", "TIMEOUT", "CANCELLED", "EXPIRED" ] }, "statusDetail": { "description": "Output only. Customer-readable message about the current status.", "readOnly": true, "type": "string" }, "source": { "description": "Optional. The location of the source files to build.", "$ref": "GoogleDevtoolsCloudbuildV1Source" }, "steps": { "description": "Required. The operations to be performed on the workspace.", "type": "array", "items": { "$ref": "GoogleDevtoolsCloudbuildV1BuildStep" } }, "results": { "description": "Output only. Results of the build.", "readOnly": true, "$ref": "GoogleDevtoolsCloudbuildV1Results" }, "createTime": { "description": "Output only. Time at which the request to create the build was received.", "readOnly": true, "type": "string", "format": "google-datetime" }, "startTime": { "description": "Output only. Time at which execution of the build was started.", "readOnly": true, "type": "string", "format": "google-datetime" }, "finishTime": { "description": "Output only. Time at which execution of the build was finished. The difference between finish_time and start_time is the duration of the build's execution.", "readOnly": true, "type": "string", "format": "google-datetime" }, "timeout": { "description": "Amount of time that this build should be allowed to run, to second granularity. If this amount of time elapses, work on the build will cease and the build status will be `TIMEOUT`. `timeout` starts ticking from `startTime`. Default time is 60 minutes.", "type": "string", "format": "google-duration" }, "images": { "description": "A list of images to be pushed upon the successful completion of all build steps. The images are pushed using the builder service account's credentials. The digests of the pushed images will be stored in the `Build` resource's results field. If any of the images fail to be pushed, the build status is marked `FAILURE`.", "type": "array", "items": { "type": "string" } }, "queueTtl": { "description": "TTL in queue for this build. If provided and the build is enqueued longer than this value, the build will expire and the build status will be `EXPIRED`. The TTL starts ticking from create_time.", "type": "string", "format": "google-duration" }, "artifacts": { "description": "Artifacts produced by the build that should be uploaded upon successful completion of all build steps.", "$ref": "GoogleDevtoolsCloudbuildV1Artifacts" }, "logsBucket": { "description": "Cloud Storage bucket where logs should be written (see [Bucket Name Requirements](https://cloud.google.com/storage/docs/bucket-naming#requirements)). Logs file names will be of the format `${logs_bucket}/log-${build_id}.txt`.", "type": "string" }, "sourceProvenance": { "description": "Output only. A permanent fixed identifier for source.", "readOnly": true, "$ref": "GoogleDevtoolsCloudbuildV1SourceProvenance" }, "buildTriggerId": { "description": "Output only. The ID of the `BuildTrigger` that triggered this build, if it was triggered automatically.", "readOnly": true, "type": "string" }, "options": { "description": "Special options for this build.", "$ref": "GoogleDevtoolsCloudbuildV1BuildOptions" }, "logUrl": { "description": "Output only. URL to logs for this build in Google Cloud Console.", "readOnly": true, "type": "string" }, "substitutions": { "description": "Substitutions data for `Build` resource.", "type": "object", "additionalProperties": { "type": "string" } }, "tags": { "description": "Tags for annotation of a `Build`. These are not docker tags.", "type": "array", "items": { "type": "string" } }, "secrets": { "description": "Secrets to decrypt using Cloud Key Management Service. Note: Secret Manager is the recommended technique for managing sensitive data with Cloud Build. Use `available_secrets` to configure builds to access secrets from Secret Manager. For instructions, see: https://cloud.google.com/cloud-build/docs/securing-builds/use-secrets", "type": "array", "items": { "$ref": "GoogleDevtoolsCloudbuildV1Secret" } }, "timing": { "description": "Output only. Stores timing information for phases of the build. Valid keys are: * BUILD: time to execute all build steps. * PUSH: time to push all artifacts including docker images and non docker artifacts. * FETCHSOURCE: time to fetch source. * SETUPBUILD: time to set up build. If the build does not specify source or images, these keys will not be included.", "readOnly": true, "type": "object", "additionalProperties": { "$ref": "GoogleDevtoolsCloudbuildV1TimeSpan" } }, "approval": { "description": "Output only. Describes this build's approval configuration, status, and result.", "readOnly": true, "$ref": "GoogleDevtoolsCloudbuildV1BuildApproval" }, "serviceAccount": { "description": "IAM service account whose credentials will be used at build runtime. Must be of the format `projects/{PROJECT_ID}/serviceAccounts/{ACCOUNT}`. ACCOUNT can be email address or uniqueId of the service account. ", "type": "string" }, "availableSecrets": { "description": "Secrets and secret environment variables.", "$ref": "GoogleDevtoolsCloudbuildV1Secrets" }, "warnings": { "description": "Output only. Non-fatal problems encountered during the execution of the build.", "readOnly": true, "type": "array", "items": { "$ref": "GoogleDevtoolsCloudbuildV1Warning" } }, "gitConfig": { "description": "Optional. Configuration for git operations.", "$ref": "GoogleDevtoolsCloudbuildV1GitConfig" }, "failureInfo": { "description": "Output only. Contains information about the build when status=FAILURE.", "readOnly": true, "$ref": "GoogleDevtoolsCloudbuildV1FailureInfo" } } }, "GoogleDevtoolsCloudbuildV1Source": { "id": "GoogleDevtoolsCloudbuildV1Source", "description": "Location of the source in a supported storage service.", "type": "object", "properties": { "storageSource": { "description": "If provided, get the source from this location in Cloud Storage.", "$ref": "GoogleDevtoolsCloudbuildV1StorageSource" }, "repoSource": { "description": "If provided, get the source from this location in a Cloud Source Repository.", "$ref": "GoogleDevtoolsCloudbuildV1RepoSource" }, "gitSource": { "description": "If provided, get the source from this Git repository.", "$ref": "GoogleDevtoolsCloudbuildV1GitSource" }, "storageSourceManifest": { "description": "If provided, get the source from this manifest in Cloud Storage. This feature is in Preview; see description [here](https://github.com/GoogleCloudPlatform/cloud-builders/tree/master/gcs-fetcher).", "$ref": "GoogleDevtoolsCloudbuildV1StorageSourceManifest" }, "connectedRepository": { "description": "Optional. If provided, get the source from this 2nd-gen Google Cloud Build repository resource.", "$ref": "GoogleDevtoolsCloudbuildV1ConnectedRepository" }, "developerConnectConfig": { "description": "If provided, get the source from this Developer Connect config.", "$ref": "GoogleDevtoolsCloudbuildV1DeveloperConnectConfig" } } }, "GoogleDevtoolsCloudbuildV1StorageSource": { "id": "GoogleDevtoolsCloudbuildV1StorageSource", "description": "Location of the source in an archive file in Cloud Storage.", "type": "object", "properties": { "bucket": { "description": "Cloud Storage bucket containing the source (see [Bucket Name Requirements](https://cloud.google.com/storage/docs/bucket-naming#requirements)).", "type": "string" }, "object": { "description": "Required. Cloud Storage object containing the source. This object must be a zipped (`.zip`) or gzipped archive file (`.tar.gz`) containing source to build.", "type": "string" }, "generation": { "description": "Optional. Cloud Storage generation for the object. If the generation is omitted, the latest generation will be used.", "type": "string", "format": "int64" }, "sourceFetcher": { "description": "Optional. Option to specify the tool to fetch the source file for the build.", "type": "string", "enumDescriptions": [ "Unspecified defaults to GSUTIL.", "Use the \"gsutil\" tool to download the source file.", "Use the Cloud Storage Fetcher tool to download the source file." ], "enum": [ "SOURCE_FETCHER_UNSPECIFIED", "GSUTIL", "GCS_FETCHER" ] } } }, "GoogleDevtoolsCloudbuildV1RepoSource": { "id": "GoogleDevtoolsCloudbuildV1RepoSource", "description": "Location of the source in a Google Cloud Source Repository.", "type": "object", "properties": { "projectId": { "description": "Optional. ID of the project that owns the Cloud Source Repository. If omitted, the project ID requesting the build is assumed.", "type": "string" }, "repoName": { "description": "Required. Name of the Cloud Source Repository.", "type": "string" }, "branchName": { "description": "Regex matching branches to build. The syntax of the regular expressions accepted is the syntax accepted by RE2 and described at https://github.com/google/re2/wiki/Syntax", "type": "string" }, "tagName": { "description": "Regex matching tags to build. The syntax of the regular expressions accepted is the syntax accepted by RE2 and described at https://github.com/google/re2/wiki/Syntax", "type": "string" }, "commitSha": { "description": "Explicit commit SHA to build.", "type": "string" }, "dir": { "description": "Optional. Directory, relative to the source root, in which to run the build. This must be a relative path. If a step's `dir` is specified and is an absolute path, this value is ignored for that step's execution.", "type": "string" }, "invertRegex": { "description": "Optional. Only trigger a build if the revision regex does NOT match the revision regex.", "type": "boolean" }, "substitutions": { "description": "Optional. Substitutions to use in a triggered build. Should only be used with RunBuildTrigger", "type": "object", "additionalProperties": { "type": "string" } } } }, "GoogleDevtoolsCloudbuildV1GitSource": { "id": "GoogleDevtoolsCloudbuildV1GitSource", "description": "Location of the source in any accessible Git repository.", "type": "object", "properties": { "url": { "description": "Required. Location of the Git repo to build. This will be used as a `git remote`, see https://git-scm.com/docs/git-remote.", "type": "string" }, "dir": { "description": "Optional. Directory, relative to the source root, in which to run the build. This must be a relative path. If a step's `dir` is specified and is an absolute path, this value is ignored for that step's execution.", "type": "string" }, "revision": { "description": "Optional. The revision to fetch from the Git repository such as a branch, a tag, a commit SHA, or any Git ref. Cloud Build uses `git fetch` to fetch the revision from the Git repository; therefore make sure that the string you provide for `revision` is parsable by the command. For information on string values accepted by `git fetch`, see https://git-scm.com/docs/gitrevisions#_specifying_revisions. For information on `git fetch`, see https://git-scm.com/docs/git-fetch.", "type": "string" } } }, "GoogleDevtoolsCloudbuildV1StorageSourceManifest": { "id": "GoogleDevtoolsCloudbuildV1StorageSourceManifest", "description": "Location of the source manifest in Cloud Storage. This feature is in Preview; see description [here](https://github.com/GoogleCloudPlatform/cloud-builders/tree/master/gcs-fetcher).", "type": "object", "properties": { "bucket": { "description": "Required. Cloud Storage bucket containing the source manifest (see [Bucket Name Requirements](https://cloud.google.com/storage/docs/bucket-naming#requirements)).", "type": "string" }, "object": { "description": "Required. Cloud Storage object containing the source manifest. This object must be a JSON file.", "type": "string" }, "generation": { "description": "Cloud Storage generation for the object. If the generation is omitted, the latest generation will be used.", "type": "string", "format": "int64" } } }, "GoogleDevtoolsCloudbuildV1ConnectedRepository": { "id": "GoogleDevtoolsCloudbuildV1ConnectedRepository", "description": "Location of the source in a 2nd-gen Google Cloud Build repository resource.", "type": "object", "properties": { "repository": { "description": "Required. Name of the Google Cloud Build repository, formatted as `projects/*/locations/*/connections/*/repositories/*`.", "type": "string" }, "dir": { "description": "Optional. Directory, relative to the source root, in which to run the build.", "type": "string" }, "revision": { "description": "Required. The revision to fetch from the Git repository such as a branch, a tag, a commit SHA, or any Git ref.", "type": "string" } } }, "GoogleDevtoolsCloudbuildV1DeveloperConnectConfig": { "id": "GoogleDevtoolsCloudbuildV1DeveloperConnectConfig", "description": "This config defines the location of a source through Developer Connect.", "type": "object", "properties": { "gitRepositoryLink": { "description": "Required. The Developer Connect Git repository link, formatted as `projects/*/locations/*/connections/*/gitRepositoryLink/*`.", "type": "string" }, "dir": { "description": "Required. Directory, relative to the source root, in which to run the build.", "type": "string" }, "revision": { "description": "Required. The revision to fetch from the Git repository such as a branch, a tag, a commit SHA, or any Git ref.", "type": "string" } } }, "GoogleDevtoolsCloudbuildV1BuildStep": { "id": "GoogleDevtoolsCloudbuildV1BuildStep", "description": "A step in the build pipeline.", "type": "object", "properties": { "name": { "description": "Required. The name of the container image that will run this particular build step. If the image is available in the host's Docker daemon's cache, it will be run directly. If not, the host will attempt to pull the image first, using the builder service account's credentials if necessary. The Docker daemon's cache will already have the latest versions of all of the officially supported build steps ([https://github.com/GoogleCloudPlatform/cloud-builders](https://github.com/GoogleCloudPlatform/cloud-builders)). The Docker daemon will also have cached many of the layers for some popular images, like \"ubuntu\", \"debian\", but they will be refreshed at the time you attempt to use them. If you built an image in a previous build step, it will be stored in the host's Docker daemon's cache and is available to use as the name for a later build step.", "type": "string" }, "env": { "description": "A list of environment variable definitions to be used when running a step. The elements are of the form \"KEY=VALUE\" for the environment variable \"KEY\" being given the value \"VALUE\".", "type": "array", "items": { "type": "string" } }, "args": { "description": "A list of arguments that will be presented to the step when it is started. If the image used to run the step's container has an entrypoint, the `args` are used as arguments to that entrypoint. If the image does not define an entrypoint, the first element in args is used as the entrypoint, and the remainder will be used as arguments.", "type": "array", "items": { "type": "string" } }, "dir": { "description": "Working directory to use when running this step's container. If this value is a relative path, it is relative to the build's working directory. If this value is absolute, it may be outside the build's working directory, in which case the contents of the path may not be persisted across build step executions, unless a `volume` for that path is specified. If the build specifies a `RepoSource` with `dir` and a step with a `dir`, which specifies an absolute path, the `RepoSource` `dir` is ignored for the step's execution.", "type": "string" }, "id": { "description": "Unique identifier for this build step, used in `wait_for` to reference this build step as a dependency.", "type": "string" }, "waitFor": { "description": "The ID(s) of the step(s) that this build step depends on. This build step will not start until all the build steps in `wait_for` have completed successfully. If `wait_for` is empty, this build step will start when all previous build steps in the `Build.Steps` list have completed successfully.", "type": "array", "items": { "type": "string" } }, "entrypoint": { "description": "Entrypoint to be used instead of the build step image's default entrypoint. If unset, the image's default entrypoint is used.", "type": "string" }, "secretEnv": { "description": "A list of environment variables which are encrypted using a Cloud Key Management Service crypto key. These values must be specified in the build's `Secret`.", "type": "array", "items": { "type": "string" } }, "volumes": { "description": "List of volumes to mount into the build step. Each volume is created as an empty volume prior to execution of the build step. Upon completion of the build, volumes and their contents are discarded. Using a named volume in only one step is not valid as it is indicative of a build request with an incorrect configuration.", "type": "array", "items": { "$ref": "GoogleDevtoolsCloudbuildV1Volume" } }, "timing": { "description": "Output only. Stores timing information for executing this build step.", "readOnly": true, "$ref": "GoogleDevtoolsCloudbuildV1TimeSpan" }, "pullTiming": { "description": "Output only. Stores timing information for pulling this build step's builder image only.", "readOnly": true, "$ref": "GoogleDevtoolsCloudbuildV1TimeSpan" }, "timeout": { "description": "Time limit for executing this build step. If not defined, the step has no time limit and will be allowed to continue to run until either it completes or the build itself times out.", "type": "string", "format": "google-duration" }, "status": { "description": "Output only. Status of the build step. At this time, build step status is only updated on build completion; step status is not updated in real-time as the build progresses.", "readOnly": true, "type": "string", "enumDescriptions": [ "Status of the build is unknown.", "Build has been created and is pending execution and queuing. It has not been queued.", "Build or step is queued; work has not yet begun.", "Build or step is being executed.", "Build or step finished successfully.", "Build or step failed to complete successfully.", "Build or step failed due to an internal cause.", "Build or step took longer than was allowed.", "Build or step was canceled by a user.", "Build was enqueued for longer than the value of `queue_ttl`." ], "enum": [ "STATUS_UNKNOWN", "PENDING", "QUEUED", "WORKING", "SUCCESS", "FAILURE", "INTERNAL_ERROR", "TIMEOUT", "CANCELLED", "EXPIRED" ] }, "allowFailure": { "description": "Allow this build step to fail without failing the entire build. If false, the entire build will fail if this step fails. Otherwise, the build will succeed, but this step will still have a failure status. Error information will be reported in the failure_detail field.", "type": "boolean" }, "exitCode": { "description": "Output only. Return code from running the step.", "readOnly": true, "type": "integer", "format": "int32" }, "allowExitCodes": { "description": "Allow this build step to fail without failing the entire build if and only if the exit code is one of the specified codes. If allow_failure is also specified, this field will take precedence.", "type": "array", "items": { "type": "integer", "format": "int32" } }, "script": { "description": "A shell script to be executed in the step. When script is provided, the user cannot specify the entrypoint or args.", "type": "string" }, "automapSubstitutions": { "description": "Option to include built-in and custom substitutions as env variables for this build step. This option will override the global option in BuildOption.", "type": "boolean" } } }, "GoogleDevtoolsCloudbuildV1Volume": { "id": "GoogleDevtoolsCloudbuildV1Volume", "description": "Volume describes a Docker container volume which is mounted into build steps in order to persist files across build step execution.", "type": "object", "properties": { "name": { "description": "Name of the volume to mount. Volume names must be unique per build step and must be valid names for Docker volumes. Each named volume must be used by at least two build steps.", "type": "string" }, "path": { "description": "Path at which to mount the volume. Paths must be absolute and cannot conflict with other volume paths on the same build step or with certain reserved volume paths.", "type": "string" } } }, "GoogleDevtoolsCloudbuildV1TimeSpan": { "id": "GoogleDevtoolsCloudbuildV1TimeSpan", "description": "Start and end times for a build execution phase.", "type": "object", "properties": { "startTime": { "description": "Start of time span.", "type": "string", "format": "google-datetime" }, "endTime": { "description": "End of time span.", "type": "string", "format": "google-datetime" } } }, "GoogleDevtoolsCloudbuildV1Results": { "id": "GoogleDevtoolsCloudbuildV1Results", "description": "Artifacts created by the build pipeline.", "type": "object", "properties": { "images": { "description": "Container images that were built as a part of the build.", "type": "array", "items": { "$ref": "GoogleDevtoolsCloudbuildV1BuiltImage" } }, "buildStepImages": { "description": "List of build step digests, in the order corresponding to build step indices.", "type": "array", "items": { "type": "string" } }, "artifactManifest": { "description": "Path to the artifact manifest for non-container artifacts uploaded to Cloud Storage. Only populated when artifacts are uploaded to Cloud Storage.", "type": "string" }, "numArtifacts": { "description": "Number of non-container artifacts uploaded to Cloud Storage. Only populated when artifacts are uploaded to Cloud Storage.", "type": "string", "format": "int64" }, "buildStepOutputs": { "description": "List of build step outputs, produced by builder images, in the order corresponding to build step indices. [Cloud Builders](https://cloud.google.com/cloud-build/docs/cloud-builders) can produce this output by writing to `$BUILDER_OUTPUT/output`. Only the first 50KB of data is stored. Note that the `$BUILDER_OUTPUT` variable is read-only and can't be substituted.", "type": "array", "items": { "type": "string", "format": "byte" } }, "artifactTiming": { "description": "Time to push all non-container artifacts to Cloud Storage.", "$ref": "GoogleDevtoolsCloudbuildV1TimeSpan" }, "pythonPackages": { "description": "Python artifacts uploaded to Artifact Registry at the end of the build.", "type": "array", "items": { "$ref": "GoogleDevtoolsCloudbuildV1UploadedPythonPackage" } }, "mavenArtifacts": { "description": "Maven artifacts uploaded to Artifact Registry at the end of the build.", "type": "array", "items": { "$ref": "GoogleDevtoolsCloudbuildV1UploadedMavenArtifact" } }, "npmPackages": { "description": "Npm packages uploaded to Artifact Registry at the end of the build.", "type": "array", "items": { "$ref": "GoogleDevtoolsCloudbuildV1UploadedNpmPackage" } } } }, "GoogleDevtoolsCloudbuildV1BuiltImage": { "id": "GoogleDevtoolsCloudbuildV1BuiltImage", "description": "An image built by the pipeline.", "type": "object", "properties": { "name": { "description": "Name used to push the container image to Google Container Registry, as presented to `docker push`.", "type": "string" }, "digest": { "description": "Docker Registry 2.0 digest.", "type": "string" }, "pushTiming": { "description": "Output only. Stores timing information for pushing the specified image.", "readOnly": true, "$ref": "GoogleDevtoolsCloudbuildV1TimeSpan" } } }, "GoogleDevtoolsCloudbuildV1UploadedPythonPackage": { "id": "GoogleDevtoolsCloudbuildV1UploadedPythonPackage", "description": "Artifact uploaded using the PythonPackage directive.", "type": "object", "properties": { "uri": { "description": "URI of the uploaded artifact.", "type": "string" }, "fileHashes": { "description": "Hash types and values of the Python Artifact.", "$ref": "GoogleDevtoolsCloudbuildV1FileHashes" }, "pushTiming": { "description": "Output only. Stores timing information for pushing the specified artifact.", "readOnly": true, "$ref": "GoogleDevtoolsCloudbuildV1TimeSpan" } } }, "GoogleDevtoolsCloudbuildV1FileHashes": { "id": "GoogleDevtoolsCloudbuildV1FileHashes", "description": "Container message for hashes of byte content of files, used in SourceProvenance messages to verify integrity of source input to the build.", "type": "object", "properties": { "fileHash": { "description": "Collection of file hashes.", "type": "array", "items": { "$ref": "GoogleDevtoolsCloudbuildV1Hash" } } } }, "GoogleDevtoolsCloudbuildV1Hash": { "id": "GoogleDevtoolsCloudbuildV1Hash", "description": "Container message for hash values.", "type": "object", "properties": { "type": { "description": "The type of hash that was performed.", "type": "string", "enumDescriptions": [ "No hash requested.", "Use a sha256 hash.", "Use a md5 hash.", "Use a sha512 hash." ], "enum": [ "NONE", "SHA256", "MD5", "SHA512" ] }, "value": { "description": "The hash value.", "type": "string", "format": "byte" } } }, "GoogleDevtoolsCloudbuildV1UploadedMavenArtifact": { "id": "GoogleDevtoolsCloudbuildV1UploadedMavenArtifact", "description": "A Maven artifact uploaded using the MavenArtifact directive.", "type": "object", "properties": { "uri": { "description": "URI of the uploaded artifact.", "type": "string" }, "fileHashes": { "description": "Hash types and values of the Maven Artifact.", "$ref": "GoogleDevtoolsCloudbuildV1FileHashes" }, "pushTiming": { "description": "Output only. Stores timing information for pushing the specified artifact.", "readOnly": true, "$ref": "GoogleDevtoolsCloudbuildV1TimeSpan" } } }, "GoogleDevtoolsCloudbuildV1UploadedNpmPackage": { "id": "GoogleDevtoolsCloudbuildV1UploadedNpmPackage", "description": "An npm package uploaded to Artifact Registry using the NpmPackage directive.", "type": "object", "properties": { "uri": { "description": "URI of the uploaded npm package.", "type": "string" }, "fileHashes": { "description": "Hash types and values of the npm package.", "$ref": "GoogleDevtoolsCloudbuildV1FileHashes" }, "pushTiming": { "description": "Output only. Stores timing information for pushing the specified artifact.", "readOnly": true, "$ref": "GoogleDevtoolsCloudbuildV1TimeSpan" } } }, "GoogleDevtoolsCloudbuildV1Artifacts": { "id": "GoogleDevtoolsCloudbuildV1Artifacts", "description": "Artifacts produced by a build that should be uploaded upon successful completion of all build steps.", "type": "object", "properties": { "images": { "description": "A list of images to be pushed upon the successful completion of all build steps. The images will be pushed using the builder service account's credentials. The digests of the pushed images will be stored in the Build resource's results field. If any of the images fail to be pushed, the build is marked FAILURE.", "type": "array", "items": { "type": "string" } }, "objects": { "description": "A list of objects to be uploaded to Cloud Storage upon successful completion of all build steps. Files in the workspace matching specified paths globs will be uploaded to the specified Cloud Storage location using the builder service account's credentials. The location and generation of the uploaded objects will be stored in the Build resource's results field. If any objects fail to be pushed, the build is marked FAILURE.", "$ref": "GoogleDevtoolsCloudbuildV1ArtifactObjects" }, "mavenArtifacts": { "description": "A list of Maven artifacts to be uploaded to Artifact Registry upon successful completion of all build steps. Artifacts in the workspace matching specified paths globs will be uploaded to the specified Artifact Registry repository using the builder service account's credentials. If any artifacts fail to be pushed, the build is marked FAILURE.", "type": "array", "items": { "$ref": "GoogleDevtoolsCloudbuildV1MavenArtifact" } }, "pythonPackages": { "description": "A list of Python packages to be uploaded to Artifact Registry upon successful completion of all build steps. The build service account credentials will be used to perform the upload. If any objects fail to be pushed, the build is marked FAILURE.", "type": "array", "items": { "$ref": "GoogleDevtoolsCloudbuildV1PythonPackage" } }, "npmPackages": { "description": "A list of npm packages to be uploaded to Artifact Registry upon successful completion of all build steps. Npm packages in the specified paths will be uploaded to the specified Artifact Registry repository using the builder service account's credentials. If any packages fail to be pushed, the build is marked FAILURE.", "type": "array", "items": { "$ref": "GoogleDevtoolsCloudbuildV1NpmPackage" } } } }, "GoogleDevtoolsCloudbuildV1ArtifactObjects": { "id": "GoogleDevtoolsCloudbuildV1ArtifactObjects", "description": "Files in the workspace to upload to Cloud Storage upon successful completion of all build steps.", "type": "object", "properties": { "location": { "description": "Cloud Storage bucket and optional object path, in the form \"gs://bucket/path/to/somewhere/\". (see [Bucket Name Requirements](https://cloud.google.com/storage/docs/bucket-naming#requirements)). Files in the workspace matching any path pattern will be uploaded to Cloud Storage with this location as a prefix.", "type": "string" }, "paths": { "description": "Path globs used to match files in the build's workspace.", "type": "array", "items": { "type": "string" } }, "timing": { "description": "Output only. Stores timing information for pushing all artifact objects.", "readOnly": true, "$ref": "GoogleDevtoolsCloudbuildV1TimeSpan" } } }, "GoogleDevtoolsCloudbuildV1MavenArtifact": { "id": "GoogleDevtoolsCloudbuildV1MavenArtifact", "description": "A Maven artifact to upload to Artifact Registry upon successful completion of all build steps.", "type": "object", "properties": { "repository": { "description": "Artifact Registry repository, in the form \"https://$REGION-maven.pkg.dev/$PROJECT/$REPOSITORY\" Artifact in the workspace specified by path will be uploaded to Artifact Registry with this location as a prefix.", "type": "string" }, "path": { "description": "Path to an artifact in the build's workspace to be uploaded to Artifact Registry. This can be either an absolute path, e.g. /workspace/my-app/target/my-app-1.0.SNAPSHOT.jar or a relative path from /workspace, e.g. my-app/target/my-app-1.0.SNAPSHOT.jar.", "type": "string" }, "artifactId": { "description": "Maven `artifactId` value used when uploading the artifact to Artifact Registry.", "type": "string" }, "groupId": { "description": "Maven `groupId` value used when uploading the artifact to Artifact Registry.", "type": "string" }, "version": { "description": "Maven `version` value used when uploading the artifact to Artifact Registry.", "type": "string" } } }, "GoogleDevtoolsCloudbuildV1PythonPackage": { "id": "GoogleDevtoolsCloudbuildV1PythonPackage", "description": "Python package to upload to Artifact Registry upon successful completion of all build steps. A package can encapsulate multiple objects to be uploaded to a single repository.", "type": "object", "properties": { "repository": { "description": "Artifact Registry repository, in the form \"https://$REGION-python.pkg.dev/$PROJECT/$REPOSITORY\" Files in the workspace matching any path pattern will be uploaded to Artifact Registry with this location as a prefix.", "type": "string" }, "paths": { "description": "Path globs used to match files in the build's workspace. For Python/ Twine, this is usually `dist/*`, and sometimes additionally an `.asc` file.", "type": "array", "items": { "type": "string" } } } }, "GoogleDevtoolsCloudbuildV1NpmPackage": { "id": "GoogleDevtoolsCloudbuildV1NpmPackage", "description": "Npm package to upload to Artifact Registry upon successful completion of all build steps.", "type": "object", "properties": { "repository": { "description": "Artifact Registry repository, in the form \"https://$REGION-npm.pkg.dev/$PROJECT/$REPOSITORY\" Npm package in the workspace specified by path will be zipped and uploaded to Artifact Registry with this location as a prefix.", "type": "string" }, "packagePath": { "description": "Path to the package.json. e.g. workspace/path/to/package", "type": "string" } } }, "GoogleDevtoolsCloudbuildV1SourceProvenance": { "id": "GoogleDevtoolsCloudbuildV1SourceProvenance", "description": "Provenance of the source. Ways to find the original source, or verify that some source was used for this build.", "type": "object", "properties": { "resolvedStorageSource": { "description": "A copy of the build's `source.storage_source`, if exists, with any generations resolved.", "$ref": "GoogleDevtoolsCloudbuildV1StorageSource" }, "resolvedRepoSource": { "description": "A copy of the build's `source.repo_source`, if exists, with any revisions resolved.", "$ref": "GoogleDevtoolsCloudbuildV1RepoSource" }, "resolvedStorageSourceManifest": { "description": "A copy of the build's `source.storage_source_manifest`, if exists, with any revisions resolved. This feature is in Preview.", "$ref": "GoogleDevtoolsCloudbuildV1StorageSourceManifest" }, "resolvedConnectedRepository": { "description": "Output only. A copy of the build's `source.connected_repository`, if exists, with any revisions resolved.", "readOnly": true, "$ref": "GoogleDevtoolsCloudbuildV1ConnectedRepository" }, "resolvedGitSource": { "description": "Output only. A copy of the build's `source.git_source`, if exists, with any revisions resolved.", "readOnly": true, "$ref": "GoogleDevtoolsCloudbuildV1GitSource" }, "fileHashes": { "description": "Output only. Hash(es) of the build source, which can be used to verify that the original source integrity was maintained in the build. Note that `FileHashes` will only be populated if `BuildOptions` has requested a `SourceProvenanceHash`. The keys to this map are file paths used as build source and the values contain the hash values for those files. If the build source came in a single package such as a gzipped tarfile (`.tar.gz`), the `FileHash` will be for the single path to that file.", "readOnly": true, "type": "object", "additionalProperties": { "$ref": "GoogleDevtoolsCloudbuildV1FileHashes" } } } }, "GoogleDevtoolsCloudbuildV1BuildOptions": { "id": "GoogleDevtoolsCloudbuildV1BuildOptions", "description": "Optional arguments to enable specific features of builds.", "type": "object", "properties": { "sourceProvenanceHash": { "description": "Requested hash for SourceProvenance.", "type": "array", "items": { "type": "string", "enumDescriptions": [ "No hash requested.", "Use a sha256 hash.", "Use a md5 hash.", "Use a sha512 hash." ], "enum": [ "NONE", "SHA256", "MD5", "SHA512" ] } }, "requestedVerifyOption": { "description": "Requested verifiability options.", "type": "string", "enumDescriptions": [ "Not a verifiable build (the default).", "Build must be verified." ], "enum": [ "NOT_VERIFIED", "VERIFIED" ] }, "machineType": { "description": "Compute Engine machine type on which to run the build.", "type": "string", "enumDescriptions": [ "Standard machine type.", "Highcpu machine with 8 CPUs.", "Highcpu machine with 32 CPUs.", "Highcpu e2 machine with 8 CPUs.", "Highcpu e2 machine with 32 CPUs.", "E2 machine with 1 CPU." ], "enumDeprecated": [ false, true, true, false, false, false ], "enum": [ "UNSPECIFIED", "N1_HIGHCPU_8", "N1_HIGHCPU_32", "E2_HIGHCPU_8", "E2_HIGHCPU_32", "E2_MEDIUM" ] }, "diskSizeGb": { "description": "Requested disk size for the VM that runs the build. Note that this is *NOT* \"disk free\"; some of the space will be used by the operating system and build utilities. Also note that this is the minimum disk size that will be allocated for the build -- the build may run with a larger disk than requested. At present, the maximum disk size is 4000GB; builds that request more than the maximum are rejected with an error.", "type": "string", "format": "int64" }, "substitutionOption": { "description": "Option to specify behavior when there is an error in the substitution checks. NOTE: this is always set to ALLOW_LOOSE for triggered builds and cannot be overridden in the build configuration file.", "type": "string", "enumDescriptions": [ "Fails the build if error in substitutions checks, like missing a substitution in the template or in the map.", "Do not fail the build if error in substitutions checks." ], "enum": [ "MUST_MATCH", "ALLOW_LOOSE" ] }, "dynamicSubstitutions": { "description": "Option to specify whether or not to apply bash style string operations to the substitutions. NOTE: this is always enabled for triggered builds and cannot be overridden in the build configuration file.", "type": "boolean" }, "automapSubstitutions": { "description": "Option to include built-in and custom substitutions as env variables for all build steps.", "type": "boolean" }, "logStreamingOption": { "description": "Option to define build log streaming behavior to Cloud Storage.", "type": "string", "enumDescriptions": [ "Service may automatically determine build log streaming behavior.", "Build logs should be streamed to Cloud Storage.", "Build logs should not be streamed to Cloud Storage; they will be written when the build is completed." ], "enum": [ "STREAM_DEFAULT", "STREAM_ON", "STREAM_OFF" ] }, "workerPool": { "description": "This field deprecated; please use `pool.name` instead.", "deprecated": true, "type": "string" }, "pool": { "description": "Optional. Specification for execution on a `WorkerPool`. See [running builds in a private pool](https://cloud.google.com/build/docs/private-pools/run-builds-in-private-pool) for more information.", "$ref": "GoogleDevtoolsCloudbuildV1PoolOption" }, "logging": { "description": "Option to specify the logging mode, which determines if and where build logs are stored.", "type": "string", "enumDescriptions": [ "The service determines the logging mode. The default is `LEGACY`. Do not rely on the default logging behavior as it may change in the future.", "Build logs are stored in Cloud Logging and Cloud Storage.", "Build logs are stored in Cloud Storage.", "This option is the same as CLOUD_LOGGING_ONLY.", "Build logs are stored in Cloud Logging. Selecting this option will not allow [logs streaming](https://cloud.google.com/sdk/gcloud/reference/builds/log).", "Turn off all logging. No build logs will be captured." ], "enumDeprecated": [ false, false, false, true, false, false ], "enum": [ "LOGGING_UNSPECIFIED", "LEGACY", "GCS_ONLY", "STACKDRIVER_ONLY", "CLOUD_LOGGING_ONLY", "NONE" ] }, "env": { "description": "A list of global environment variable definitions that will exist for all build steps in this build. If a variable is defined in both globally and in a build step, the variable will use the build step value. The elements are of the form \"KEY=VALUE\" for the environment variable \"KEY\" being given the value \"VALUE\".", "type": "array", "items": { "type": "string" } }, "secretEnv": { "description": "A list of global environment variables, which are encrypted using a Cloud Key Management Service crypto key. These values must be specified in the build's `Secret`. These variables will be available to all build steps in this build.", "type": "array", "items": { "type": "string" } }, "volumes": { "description": "Global list of volumes to mount for ALL build steps Each volume is created as an empty volume prior to starting the build process. Upon completion of the build, volumes and their contents are discarded. Global volume names and paths cannot conflict with the volumes defined a build step. Using a global volume in a build with only one step is not valid as it is indicative of a build request with an incorrect configuration.", "type": "array", "items": { "$ref": "GoogleDevtoolsCloudbuildV1Volume" } }, "defaultLogsBucketBehavior": { "description": "Optional. Option to specify how default logs buckets are setup.", "type": "string", "enumDescriptions": [ "Unspecified.", "Bucket is located in user-owned project in the same region as the build. The builder service account must have access to create and write to Cloud Storage buckets in the build project.", "Bucket is located in a Google-owned project and is not regionalized." ], "enum": [ "DEFAULT_LOGS_BUCKET_BEHAVIOR_UNSPECIFIED", "REGIONAL_USER_OWNED_BUCKET", "LEGACY_BUCKET" ] } } }, "GoogleDevtoolsCloudbuildV1PoolOption": { "id": "GoogleDevtoolsCloudbuildV1PoolOption", "description": "Details about how a build should be executed on a `WorkerPool`. See [running builds in a private pool](https://cloud.google.com/build/docs/private-pools/run-builds-in-private-pool) for more information.", "type": "object", "properties": { "name": { "description": "The `WorkerPool` resource to execute the build on. You must have `cloudbuild.workerpools.use` on the project hosting the WorkerPool. Format projects/{project}/locations/{location}/workerPools/{workerPoolId}", "type": "string" } } }, "GoogleDevtoolsCloudbuildV1Secret": { "id": "GoogleDevtoolsCloudbuildV1Secret", "description": "Pairs a set of secret environment variables containing encrypted values with the Cloud KMS key to use to decrypt the value. Note: Use `kmsKeyName` with `available_secrets` instead of using `kmsKeyName` with `secret`. For instructions see: https://cloud.google.com/cloud-build/docs/securing-builds/use-encrypted-credentials.", "type": "object", "properties": { "kmsKeyName": { "description": "Cloud KMS key name to use to decrypt these envs.", "type": "string" }, "secretEnv": { "description": "Map of environment variable name to its encrypted value. Secret environment variables must be unique across all of a build's secrets, and must be used by at least one build step. Values can be at most 64 KB in size. There can be at most 100 secret values across all of a build's secrets.", "type": "object", "additionalProperties": { "type": "string", "format": "byte" } } } }, "GoogleDevtoolsCloudbuildV1BuildApproval": { "id": "GoogleDevtoolsCloudbuildV1BuildApproval", "description": "BuildApproval describes a build's approval configuration, state, and result.", "type": "object", "properties": { "state": { "description": "Output only. The state of this build's approval.", "readOnly": true, "type": "string", "enumDescriptions": [ "Default enum type. This should not be used.", "Build approval is pending.", "Build approval has been approved.", "Build approval has been rejected.", "Build was cancelled while it was still pending approval." ], "enum": [ "STATE_UNSPECIFIED", "PENDING", "APPROVED", "REJECTED", "CANCELLED" ] }, "config": { "description": "Output only. Configuration for manual approval of this build.", "readOnly": true, "$ref": "GoogleDevtoolsCloudbuildV1ApprovalConfig" }, "result": { "description": "Output only. Result of manual approval for this Build.", "readOnly": true, "$ref": "GoogleDevtoolsCloudbuildV1ApprovalResult" } } }, "GoogleDevtoolsCloudbuildV1ApprovalConfig": { "id": "GoogleDevtoolsCloudbuildV1ApprovalConfig", "description": "ApprovalConfig describes configuration for manual approval of a build.", "type": "object", "properties": { "approvalRequired": { "description": "Whether or not approval is needed. If this is set on a build, it will become pending when created, and will need to be explicitly approved to start.", "type": "boolean" } } }, "GoogleDevtoolsCloudbuildV1ApprovalResult": { "id": "GoogleDevtoolsCloudbuildV1ApprovalResult", "description": "ApprovalResult describes the decision and associated metadata of a manual approval of a build.", "type": "object", "properties": { "approverAccount": { "description": "Output only. Email of the user that called the ApproveBuild API to approve or reject a build at the time that the API was called.", "readOnly": true, "type": "string" }, "approvalTime": { "description": "Output only. The time when the approval decision was made.", "readOnly": true, "type": "string", "format": "google-datetime" }, "decision": { "description": "Required. The decision of this manual approval.", "type": "string", "enumDescriptions": [ "Default enum type. This should not be used.", "Build is approved.", "Build is rejected." ], "enum": [ "DECISION_UNSPECIFIED", "APPROVED", "REJECTED" ] }, "comment": { "description": "Optional. An optional comment for this manual approval result.", "type": "string" }, "url": { "description": "Optional. An optional URL tied to this manual approval result. This field is essentially the same as comment, except that it will be rendered by the UI differently. An example use case is a link to an external job that approved this Build.", "type": "string" } } }, "GoogleDevtoolsCloudbuildV1Secrets": { "id": "GoogleDevtoolsCloudbuildV1Secrets", "description": "Secrets and secret environment variables.", "type": "object", "properties": { "secretManager": { "description": "Secrets in Secret Manager and associated secret environment variable.", "type": "array", "items": { "$ref": "GoogleDevtoolsCloudbuildV1SecretManagerSecret" } }, "inline": { "description": "Secrets encrypted with KMS key and the associated secret environment variable.", "type": "array", "items": { "$ref": "GoogleDevtoolsCloudbuildV1InlineSecret" } } } }, "GoogleDevtoolsCloudbuildV1SecretManagerSecret": { "id": "GoogleDevtoolsCloudbuildV1SecretManagerSecret", "description": "Pairs a secret environment variable with a SecretVersion in Secret Manager.", "type": "object", "properties": { "versionName": { "description": "Resource name of the SecretVersion. In format: projects/*/secrets/*/versions/*", "type": "string" }, "env": { "description": "Environment variable name to associate with the secret. Secret environment variables must be unique across all of a build's secrets, and must be used by at least one build step.", "type": "string" } } }, "GoogleDevtoolsCloudbuildV1InlineSecret": { "id": "GoogleDevtoolsCloudbuildV1InlineSecret", "description": "Pairs a set of secret environment variables mapped to encrypted values with the Cloud KMS key to use to decrypt the value.", "type": "object", "properties": { "kmsKeyName": { "description": "Resource name of Cloud KMS crypto key to decrypt the encrypted value. In format: projects/*/locations/*/keyRings/*/cryptoKeys/*", "type": "string" }, "envMap": { "description": "Map of environment variable name to its encrypted value. Secret environment variables must be unique across all of a build's secrets, and must be used by at least one build step. Values can be at most 64 KB in size. There can be at most 100 secret values across all of a build's secrets.", "type": "object", "additionalProperties": { "type": "string", "format": "byte" } } } }, "GoogleDevtoolsCloudbuildV1Warning": { "id": "GoogleDevtoolsCloudbuildV1Warning", "description": "A non-fatal problem encountered during the execution of the build.", "type": "object", "properties": { "text": { "description": "Explanation of the warning generated.", "type": "string" }, "priority": { "description": "The priority for this warning.", "type": "string", "enumDescriptions": [ "Should not be used.", "e.g. deprecation warnings and alternative feature highlights.", "e.g. automated detection of possible issues with the build.", "e.g. alerts that a feature used in the build is pending removal" ], "enum": [ "PRIORITY_UNSPECIFIED", "INFO", "WARNING", "ALERT" ] } } }, "GoogleDevtoolsCloudbuildV1GitConfig": { "id": "GoogleDevtoolsCloudbuildV1GitConfig", "description": "GitConfig is a configuration for git operations.", "type": "object", "properties": { "http": { "description": "Configuration for HTTP related git operations.", "$ref": "GoogleDevtoolsCloudbuildV1HttpConfig" } } }, "GoogleDevtoolsCloudbuildV1HttpConfig": { "id": "GoogleDevtoolsCloudbuildV1HttpConfig", "description": "HttpConfig is a configuration for HTTP related git operations.", "type": "object", "properties": { "proxySecretVersionName": { "description": "SecretVersion resource of the HTTP proxy URL. The Service Account used in the build (either the default Service Account or user-specified Service Account) should have `secretmanager.versions.access` permissions on this secret. The proxy URL should be in format `protocol://@]proxyhost[:port]`.", "type": "string" } } }, "GoogleDevtoolsCloudbuildV1FailureInfo": { "id": "GoogleDevtoolsCloudbuildV1FailureInfo", "description": "A fatal problem encountered during the execution of the build.", "type": "object", "properties": { "type": { "description": "The name of the failure.", "type": "string", "enumDescriptions": [ "Type unspecified", "Unable to push the image to the repository.", "Final image not found.", "Unauthorized push of the final image.", "Backend logging failures. Should retry.", "A build step has failed.", "The source fetching has failed." ], "enum": [ "FAILURE_TYPE_UNSPECIFIED", "PUSH_FAILED", "PUSH_IMAGE_NOT_FOUND", "PUSH_NOT_AUTHORIZED", "LOGGING_FAILURE", "USER_BUILD_STEP", "FETCH_SOURCE_FAILED" ] }, "detail": { "description": "Explains the failure issue in more detail using hard-coded text.", "type": "string" } } } }, "rootUrl": "https://run.googleapis.com/", "description": "Deploy and manage user provided container images that scale automatically based on incoming requests. The Cloud Run Admin API v1 follows the Knative Serving API specification, while v2 is aligned with Google Cloud AIP-based API standards, as described in https://google.aip.dev/.", "ownerName": "Google" }