"description":"Recreates the required App Engine features for the specified App Engine application, for example a Cloud Storage bucket or App Engine service account. Use this method if you receive an error message about a missing feature, for example, Error retrieving the App Engine service account.",
"request":{
"$ref":"RepairApplicationRequest"
},
"response":{
"$ref":"Operation"
},
"parameterOrder":[
"appsId"
],
"httpMethod":"POST",
"parameters":{
"appsId":{
"location":"path",
"description":"Part of `name`. Name of the application to repair. Example: apps/myapp",
"description":"Updates the specified Application resource. You can update the following fields:\nauth_domain - Google authentication domain for controlling user access to the application.\ndefault_cookie_expiration - Cookie expiration policy for the application.",
"description":"Creates an App Engine application for a Google Cloud Platform project. Required fields:\nid - The ID of the target Cloud Platform project.\nlocation - The region (https://cloud.google.com/appengine/docs/locations) where you want the App Engine application located.For more information about App Engine applications, see Managing Projects, Applications, and Billing (https://cloud.google.com/appengine/docs/python/console/)."
"description":"Replaces the entire firewall ruleset in one bulk operation. This overrides and replaces the rules of an existing firewall with the new rules.If the final rule does not match traffic with the '*' wildcard IP range, then an \"allow all\" rule is explicitly added to the end of the list.",
"response":{
"$ref":"BatchUpdateIngressRulesResponse"
},
"parameterOrder":[
"appsId"
],
"httpMethod":"POST"
},
"delete":{
"response":{
"$ref":"Empty"
},
"parameterOrder":[
"appsId",
"ingressRulesId"
],
"httpMethod":"DELETE",
"scopes":[
"https://www.googleapis.com/auth/cloud-platform"
],
"parameters":{
"appsId":{
"description":"Part of `name`. Name of the Firewall resource to delete. Example: apps/myapp/firewall/ingressRules/100.",
"type":"string",
"required":true,
"location":"path"
},
"ingressRulesId":{
"location":"path",
"description":"Part of `name`. See documentation of `appsId`.",
"description":"Continuation token for fetching the next page of results.",
"type":"string",
"location":"query"
},
"appsId":{
"location":"path",
"description":"Part of `parent`. Name of the Firewall collection to retrieve. Example: apps/myapp/firewall/ingressRules.",
"type":"string",
"required":true
},
"pageSize":{
"format":"int32",
"description":"Maximum results to return per page.",
"type":"integer",
"location":"query"
},
"matchingAddress":{
"location":"query",
"description":"A valid IP Address. If set, only rules matching this address will be returned. The first returned rule will be the rule that fires on requests from this IP.",
"description":"Updates the specified SSL certificate. To renew a certificate and maintain its existing domain mappings, update certificate_data with a new certificate. The new certificate must be applicable to the same domains as the original certificate. The certificate display_name may also be updated.",
"description":"Standard field mask for the set of fields to be updated. Updates are only supported on the certificate_raw_data and display_name fields.",
"description":"Standard field mask for the set of fields to be updated.",
"type":"string",
"location":"query"
},
"servicesId":{
"location":"path",
"description":"Part of `name`. See documentation of `appsId`.",
"type":"string",
"required":true
},
"appsId":{
"description":"Part of `name`. Name of the resource to update. Example: apps/myapp/services/default.",
"type":"string",
"required":true,
"location":"path"
},
"migrateTraffic":{
"type":"boolean",
"location":"query",
"description":"Set to true to gradually shift traffic to one or more versions that you specify. By default, traffic is shifted immediately. For gradual traffic migration, the target versions must be located within instances that are configured for both warmup requests (https://cloud.google.com/appengine/docs/admin-api/reference/rest/v1beta/apps.services.versions#inboundservicetype) and automatic scaling (https://cloud.google.com/appengine/docs/admin-api/reference/rest/v1beta/apps.services.versions#automaticscaling). You must specify the shardBy (https://cloud.google.com/appengine/docs/admin-api/reference/rest/v1beta/apps.services#shardby) field in the Service resource. Gradual traffic migration is not supported in the App Engine flexible environment. For examples, see Migrating and Splitting Traffic (https://cloud.google.com/appengine/docs/admin-api/migrating-splitting-traffic)."
"description":"Updates the specified Version resource. You can specify the following fields depending on the App Engine environment and type of scaling that the version resource uses:\nserving_status (https://cloud.google.com/appengine/docs/admin-api/reference/rest/v1beta/apps.services.versions#Version.FIELDS.serving_status): For Version resources that use basic scaling, manual scaling, or run in the App Engine flexible environment.\ninstance_class (https://cloud.google.com/appengine/docs/admin-api/reference/rest/v1beta/apps.services.versions#Version.FIELDS.instance_class): For Version resources that run in the App Engine standard environment.\nautomatic_scaling.min_idle_instances (https://cloud.google.com/appengine/docs/admin-api/reference/rest/v1beta/apps.services.versions#Version.FIELDS.automatic_scaling): For Version resources that use automatic scaling and run in the App Engine standard environment.\nautomatic_scaling.max_idle_instances (https://cloud.google.com/appengine/docs/admin-api/reference/rest/v1beta/apps.services.versions#Version.FIELDS.automatic_scaling): For Version resources that use automatic scaling and run in the App Engine standard environment.\nautomatic_scaling.min_total_instances (https://cloud.google.com/appengine/docs/admin-api/reference/rest/v1beta/apps.services.versions#Version.FIELDS.automatic_scaling): For Version resources that use automatic scaling and run in the App Engine Flexible environment.\nautomatic_scaling.max_total_instances (https://cloud.google.com/appengine/docs/admin-api/reference/rest/v1beta/apps.services.versions#Version.FIELDS.automatic_scaling): For Version resources that use automatic scaling and run in the App Engine Flexible environment.\nautomatic_scaling.cool_down_period_sec (https://cloud.google.com/appengine/docs/admin-api/reference/rest/v1beta/apps.services.versions#Version.FIELDS.automatic_scaling): For Version resources that use automatic scaling and run in the App Engine Flexible environment.\nautomatic_scaling.cpu_utilization.target_utilization (https://cloud.google.com/appengine/docs/admin-api/reference/rest/v1beta/apps.services.versions#Version.FIELDS.automatic_scaling): For Version resources that use automatic scaling and run in the App Engine Flexible environment."
"description":"Gets the specified Version resource. By default, only a BASIC_VIEW will be returned. Specify the FULL_VIEW parameter to get the full resource."
"description":"Enables debugging on a VM instance. This allows you to use the SSH command to connect to the virtual machine where the instance lives. While in \"debug mode\", the instance continues to serve live traffic. You should delete the instance when you are done debugging and then allow the system to take over and determine if another instance should be started.Only applicable for instances in App Engine flexible environment.",
"request":{
"$ref":"DebugInstanceRequest"
},
"response":{
"$ref":"Operation"
},
"parameterOrder":[
"appsId",
"servicesId",
"versionsId",
"instancesId"
],
"httpMethod":"POST",
"parameters":{
"servicesId":{
"description":"Part of `name`. See documentation of `appsId`.",
"description":"Lists the instances of a version.Tip: To aggregate details about instances over time, see the Stackdriver Monitoring API (https://cloud.google.com/monitoring/api/ref_v3/rest/v3/projects.timeSeries/list).",
"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.",
"httpMethod":"GET",
"parameterOrder":[
"appsId",
"operationsId"
],
"response":{
"$ref":"Operation"
},
"parameters":{
"operationsId":{
"location":"path",
"description":"Part of `name`. See documentation of `appsId`.",
"type":"string",
"required":true
},
"appsId":{
"location":"path",
"description":"Part of `name`. The name of the operation resource.",
"description":"Part of `name`. The name of the operation's parent resource.",
"type":"string",
"required":true
},
"pageSize":{
"location":"query",
"format":"int32",
"description":"The standard list page size.",
"type":"integer"
}
},
"flatPath":"v1beta/apps/{appsId}/operations",
"id":"appengine.apps.operations.list",
"path":"v1beta/apps/{appsId}/operations",
"description":"Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns UNIMPLEMENTED.NOTE: the name binding allows API services to override the binding to use different resource name schemes, such as users/*/operations. To override the binding, API services can add a binding such as \"/v1/{name=users/*}/operations\" to their service configuration. For backwards compatibility, the default name includes the operations collection id, however overriding users must ensure the name binding is the parent resource, without the operations collection id.",
"response":{
"$ref":"ListOperationsResponse"
},
"parameterOrder":[
"appsId"
],
"httpMethod":"GET"
}
}
},
"domainMappings":{
"methods":{
"delete":{
"description":"Deletes the specified domain mapping. A user must be authorized to administer the associated domain in order to delete a DomainMapping resource.",
"httpMethod":"DELETE",
"response":{
"$ref":"Operation"
},
"parameterOrder":[
"appsId",
"domainMappingsId"
],
"parameters":{
"appsId":{
"description":"Part of `name`. Name of the resource to delete. Example: apps/myapp/domainMappings/example.com.",
"type":"string",
"required":true,
"location":"path"
},
"domainMappingsId":{
"description":"Part of `name`. See documentation of `appsId`.",
"description":"Updates the specified domain mapping. To map an SSL certificate to a domain mapping, update certificate_id to point to an AuthorizedCertificate resource. A user must be authorized to administer the associated domain in order to update a DomainMapping resource.",
"response":{
"$ref":"Operation"
},
"parameterOrder":[
"appsId",
"domainMappingsId"
],
"httpMethod":"PATCH",
"scopes":[
"https://www.googleapis.com/auth/cloud-platform"
],
"parameters":{
"updateMask":{
"format":"google-fieldmask",
"description":"Standard field mask for the set of fields to be updated.",
"type":"string",
"location":"query"
},
"appsId":{
"location":"path",
"description":"Part of `name`. Name of the resource to update. Example: apps/myapp/domainMappings/example.com.",
"type":"string",
"required":true
},
"domainMappingsId":{
"location":"path",
"description":"Part of `name`. See documentation of `appsId`.",
"type":"string",
"required":true
}
}
},
"get":{
"description":"Gets the specified domain mapping.",
"response":{
"$ref":"DomainMapping"
},
"parameterOrder":[
"appsId",
"domainMappingsId"
],
"httpMethod":"GET",
"parameters":{
"appsId":{
"description":"Part of `name`. Name of the resource requested. Example: apps/myapp/domainMappings/example.com.",
"type":"string",
"required":true,
"location":"path"
},
"domainMappingsId":{
"description":"Part of `name`. See documentation of `appsId`.",
"description":"Continuation token for fetching the next page of results.",
"type":"string",
"location":"query"
},
"appsId":{
"location":"path",
"description":"Part of `parent`. Name of the parent Application resource. Example: apps/myapp.",
"type":"string",
"required":true
},
"pageSize":{
"type":"integer",
"location":"query",
"format":"int32",
"description":"Maximum results to return per page."
}
},
"flatPath":"v1beta/apps/{appsId}/domainMappings"
},
"create":{
"scopes":[
"https://www.googleapis.com/auth/cloud-platform"
],
"parameters":{
"appsId":{
"location":"path",
"description":"Part of `parent`. Name of the parent Application resource. Example: apps/myapp.",
"type":"string",
"required":true
}
},
"flatPath":"v1beta/apps/{appsId}/domainMappings",
"path":"v1beta/apps/{appsId}/domainMappings",
"id":"appengine.apps.domainMappings.create",
"request":{
"$ref":"DomainMapping"
},
"description":"Maps a domain to an application. A user must be authorized to administer a domain in order to map it to an application. For a list of available authorized domains, see AuthorizedDomains.ListAuthorizedDomains.",
"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.",
"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.",
"description":"Health checking configuration for VM instances. Unhealthy instances are killed and replaced with new instances. Only applicable for instances in App Engine flexible environment.",
"description":"Number of consecutive failed checks required before removing traffic.",
"type":"integer"
},
"timeout":{
"format":"google-duration",
"description":"Time before the check is considered failed.",
"type":"string"
},
"appStartTimeout":{
"format":"google-duration",
"description":"A maximum time limit on application initialization, measured from moment the application successfully replies to a healthcheck until it is ready to serve traffic.",
"description":"Public SSH key to add to the instance. Examples:\n[USERNAME]:ssh-rsa [KEY_VALUE] [USERNAME]\n[USERNAME]:ssh-rsa [KEY_VALUE] google-ssh {\"userName\":\"[USERNAME]\",\"expireOn\":\"[EXPIRE_TIME]\"}For more information, see Adding and Removing SSH Keys (https://cloud.google.com/compute/docs/instances/adding-removing-ssh-keys).",
"type":"string"
}
},
"id":"DebugInstanceRequest",
"description":"Request message for Instances.DebugInstance.",
"description":"Name of the resource that this operation is acting on. Example: apps/myapp/services/default.@OutputOnly",
"type":"string"
},
"user":{
"description":"User who requested this operation.@OutputOnly",
"type":"string"
}
},
"id":"OperationMetadataV1Beta5",
"description":"Metadata for the given google.longrunning.Operation."
},
"Version":{
"id":"Version",
"description":"A Version resource is a specific set of source code and configuration files that are deployed into a service.",
"type":"object",
"properties":{
"createTime":{
"format":"google-datetime",
"description":"Time that this version was created.@OutputOnly",
"type":"string"
},
"inboundServices":{
"description":"Before an application can receive email or XMPP messages, the application must be configured to enable the service.",
"items":{
"enum":[
"INBOUND_SERVICE_UNSPECIFIED",
"INBOUND_SERVICE_MAIL",
"INBOUND_SERVICE_MAIL_BOUNCE",
"INBOUND_SERVICE_XMPP_ERROR",
"INBOUND_SERVICE_XMPP_MESSAGE",
"INBOUND_SERVICE_XMPP_SUBSCRIBE",
"INBOUND_SERVICE_XMPP_PRESENCE",
"INBOUND_SERVICE_CHANNEL_PRESENCE",
"INBOUND_SERVICE_WARMUP"
],
"type":"string"
},
"type":"array",
"enumDescriptions":[
"Not specified.",
"Allows an application to receive mail.",
"Allows an application to receive email-bound notifications.",
"Allows an application to receive error stanzas.",
"Allows an application to receive instant messages.",
"Allows an application to receive user subscription POSTs.",
"Allows an application to receive a user's chat presence.",
"Registers an application for notifications when a client connects or disconnects from a channel.",
"Enables warmup requests."
]
},
"resources":{
"description":"Machine resources for this version. Only applicable for VM runtimes.",
"$ref":"Resources"
},
"errorHandlers":{
"items":{
"$ref":"ErrorHandler"
},
"type":"array",
"description":"Custom static error pages. Limited to 10KB per page.Only returned in GET requests if view=FULL is set."
},
"defaultExpiration":{
"format":"google-duration",
"description":"Duration that static files should be cached by web proxies and browsers. Only applicable if the corresponding StaticFilesHandler (https://cloud.google.com/appengine/docs/admin-api/reference/rest/v1beta/apps.services.versions#staticfileshandler) does not specify its own expiration time.Only returned in GET requests if view=FULL is set.",
"type":"string"
},
"libraries":{
"description":"Configuration for third-party Python runtime libraries that are required by the application.Only returned in GET requests if view=FULL is set.",
"items":{
"$ref":"Library"
},
"type":"array"
},
"nobuildFilesRegex":{
"description":"Files that match this pattern will not be built into this version. Only applicable for Go runtimes.Only returned in GET requests if view=FULL is set.",
"description":"A service with basic scaling will create an instance when the application receives a request. The instance will be turned down when the app becomes idle. Basic scaling is ideal for work that is intermittent or driven by user activity."
"description":"Relative name of the version within the service. Example: v1. Version names can contain only lowercase letters, numbers, or hyphens. Reserved names: \"default\", \"latest\", and any name with the prefix \"ah-\"."
},
"createdBy":{
"description":"Email address of the user who created this version.@OutputOnly",
"description":"Configures liveness health checking for VM instances. Unhealthy instances are stopped and replaced with new instancesOnly returned in GET requests if view=FULL is set."
"description":"An ordered list of URL-matching patterns that should be applied to incoming requests. The first matching URL handles the request and other request handlers are not attempted.Only returned in GET requests if view=FULL is set."
"description":"Configures health checking for VM instances. Unhealthy instances are stopped and replaced with new instances. Only applicable for VM runtimes.Only returned in GET requests if view=FULL is set."
"description":"Configures readiness health checking for VM instances. Unhealthy instances are not put into the backend traffic rotation.Only returned in GET requests if view=FULL is set."
"description":"A service with manual scaling runs continuously, allowing you to perform complex initialization and rely on the state of its memory over time.",
"$ref":"ManualScaling"
},
"name":{
"description":"Full path to the Version resource in the API. Example: apps/myapp/services/default/versions/v1.@OutputOnly",
"description":"Serving configuration for Google Cloud Endpoints (https://cloud.google.com/appengine/docs/python/endpoints/).Only returned in GET requests if view=FULL is set."
"description":"Cloud Endpoints configuration.If endpoints_api_service is set, the Cloud Endpoints Extensible Service Proxy will be provided to serve the API implemented by the app.",
"$ref":"EndpointsApiService"
},
"vm":{
"description":"Whether to deploy this version in a container on a virtual machine.",
"type":"boolean"
},
"versionUrl":{
"description":"Serving URL for this version. Example: \"https://myversion-dot-myservice-dot-myapp.appspot.com\"@OutputOnly",
"type":"string"
},
"instanceClass":{
"description":"Instance class that is used to run this version. Valid values are:\nAutomaticScaling: F1, F2, F4, F4_1G\nManualScaling or BasicScaling: B1, B2, B4, B8, B4_1GDefaults to F1 for AutomaticScaling and B1 for ManualScaling or BasicScaling.",
"description":"Current serving status of this version. Only the versions with a SERVING status create instances and can be billed.SERVING_STATUS_UNSPECIFIED is an invalid value. Defaults to SERVING.",
"description":"The version of the API in the given runtime environment. Please see the app.yaml reference for valid values at https://cloud.google.com/appengine/docs/standard/\u003clanguage\u003e/config/appref"
"description":"Code and application artifacts that make up this version.Only returned in GET requests if view=FULL is set."
}
}
},
"RepairApplicationRequest":{
"id":"RepairApplicationRequest",
"description":"Request message for 'Applications.RepairApplication'.",
"type":"object",
"properties":{}
},
"CertificateRawData":{
"description":"An SSL certificate obtained from a certificate authority.",
"type":"object",
"properties":{
"privateKey":{
"description":"Unencrypted PEM encoded RSA private key. This field is set once on certificate creation and then encrypted. The key size must be 2048 bits or fewer. Must include the header and footer. Example: \u003cpre\u003e -----BEGIN RSA PRIVATE KEY----- \u003cunencrypted_key_value\u003e -----END RSA PRIVATE KEY----- \u003c/pre\u003e @InputOnly",
"description":"PEM encoded x.509 public key certificate. This field is set once on certificate creation. Must include the header and footer. Example: \u003cpre\u003e -----BEGIN CERTIFICATE----- \u003ccertificate_value\u003e -----END CERTIFICATE----- \u003c/pre\u003e",
"description":"URL source to use to fetch this file. Must be a URL to a resource in Google Cloud Storage in the form 'http(s)://storage.googleapis.com/\u003cbucket\u003e/\u003cobject\u003e'."
}
},
"id":"FileInfo"
},
"ScriptHandler":{
"description":"Executes a script to handle the request that matches the URL pattern.",
"type":"object",
"properties":{
"scriptPath":{
"description":"Path to the script from the application root directory.",
"type":"string"
}
},
"id":"ScriptHandler"
},
"OperationMetadataExperimental":{
"description":"Metadata for the given google.longrunning.Operation.",
"type":"object",
"properties":{
"method":{
"description":"API method that initiated this operation. Example: google.appengine.experimental.CustomDomains.CreateCustomDomain.@OutputOnly",
"description":"A domain that a user has been authorized to administer. To authorize use of a domain, verify ownership via Webmaster Central (https://www.google.com/webmasters/verification/home).",
"description":"Traffic routing configuration for versions within a single service. Traffic splits define how traffic directed to the service is assigned to versions.",
"description":"Mapping from version IDs within the service to fractional (0.000, 1] allocations of traffic for that version. Each version can be specified only once, but some versions in the service may not have any traffic allocation. Services that have traffic allocated cannot be deleted until either the service is deleted or their traffic allocation is removed. Allocations must sum to 1. Up to two decimal place precision is supported for IP-based splits and up to three decimal places is supported for cookie-based splits.",
"type":"object"
},
"shardBy":{
"enum":[
"UNSPECIFIED",
"COOKIE",
"IP",
"RANDOM"
],
"description":"Mechanism used to determine which version a request is sent to. The traffic selection algorithm will be stable for either type until allocations are changed.",
"type":"string",
"enumDescriptions":[
"Diversion method unspecified.",
"Diversion based on a specially named cookie, \"GOOGAPPUID.\" The cookie must be set by the application itself or no diversion will occur.",
"Diversion based on applying the modulus operation to a fingerprint of the IP address.",
"Diversion based on weighted random assignment. An incoming request is randomly routed to a version in the traffic split, with probability proportional to the version's traffic share."
]
}
},
"id":"TrafficSplit"
},
"OperationMetadataV1Beta":{
"type":"object",
"properties":{
"target":{
"description":"Name of the resource that this operation is acting on. Example: apps/myapp/services/default.@OutputOnly",
"type":"string"
},
"user":{
"description":"User who requested this operation.@OutputOnly",
"type":"string"
},
"ephemeralMessage":{
"description":"Ephemeral message that may change every time the operation is polled. @OutputOnly",
"type":"string"
},
"method":{
"description":"API method that initiated this operation. Example: google.appengine.v1beta.Versions.CreateVersion.@OutputOnly",
"type":"string"
},
"endTime":{
"format":"google-datetime",
"description":"Time that this operation completed.@OutputOnly",
"description":"The Docker image for the container that runs the version. Only applicable for instances running in the App Engine flexible environment."
"description":"Manifest of the files stored in Google Cloud Storage that are included as part of this version. All files must be readable using the credentials supplied with this call.",
"description":"A certificate managed by App Engine.",
"type":"object",
"properties":{
"lastRenewalTime":{
"format":"google-datetime",
"description":"Time at which the certificate was last renewed. The renewal process is fully managed. Certificate renewal will automatically occur before the certificate expires. Renewal errors can be tracked via ManagementStatus.@OutputOnly",
"Certificate was successfully obtained and inserted into the serving system.",
"Certificate is under active attempts to acquire or renew.",
"Most recent renewal failed due to an invalid DNS setup and will be retried. Renewal attempts will continue to fail until the certificate domain's DNS configuration is fixed. The last successfully provisioned certificate may still be serving.",
"All renewal attempts have been exhausted, likely due to an invalid DNS setup."
"description":"Pathname within the host. Must start with a \"/\". A single \"*\" can be included at the end of the path.The sum of the lengths of the domain and path may not exceed 100 characters.",
"description":"Domain name to match against. The wildcard \"*\" is supported if specified before a period: \"*.\".Defaults to matching all domains: \"*\".",
"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:\nservice Foo {\n rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty);\n}\nThe JSON representation for Empty is empty JSON object {}.",
"type":"object",
"properties":{},
"id":"Empty"
},
"DomainMapping":{
"id":"DomainMapping",
"description":"A domain serving an App Engine application.",
"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.@OutputOnly",
"description":"Relative name of the domain serving the application. Example: example.com.",
"type":"string"
}
}
},
"ZipInfo":{
"type":"object",
"properties":{
"filesCount":{
"type":"integer",
"format":"int32",
"description":"An estimate of the number of files in a zip for a zip deployment. If set, must be greater than or equal to the actual number of files. Used for optimizing performance; if not provided, deployment may be slow."
},
"sourceUrl":{
"description":"URL of the zip file to deploy from. Must be a URL to a resource in Google Cloud Storage in the form 'http(s)://storage.googleapis.com/\u003cbucket\u003e/\u003cobject\u003e'.",
"description":"Scheduler settings for standard environment."
},
"minIdleInstances":{
"format":"int32",
"description":"Minimum number of idle instances that should be maintained for this version. Only applicable for the default version of a service.",
"type":"integer"
},
"maxTotalInstances":{
"format":"int32",
"description":"Maximum number of instances that should be started to handle requests.",
"type":"integer"
},
"minTotalInstances":{
"format":"int32",
"description":"Minimum number of instances that should be maintained for this version.",
"type":"integer"
},
"networkUtilization":{
"description":"Target scaling by network usage.",
"$ref":"NetworkUtilization"
},
"coolDownPeriod":{
"format":"google-duration",
"description":"Amount of time that the Autoscaler (https://cloud.google.com/compute/docs/autoscaler/) should wait between changes to the number of virtual machines. Only applicable for VM runtimes.",
"type":"string"
},
"maxConcurrentRequests":{
"format":"int32",
"description":"Number of concurrent requests an automatic scaling instance can accept before the scheduler spawns a new instance.Defaults to a runtime-specific value.",
"type":"integer"
},
"maxPendingLatency":{
"format":"google-duration",
"description":"Maximum amount of time that a request should wait in the pending queue before starting a new instance to handle it.",
"description":"An SSL certificate that a user has been authorized to administer. A user is authorized to administer any certificate that applies to one of their authorized domains.",
"description":"Only applicable if this certificate is managed by App Engine. Managed certificates are tied to the lifecycle of a DomainMapping and cannot be updated or deleted via the AuthorizedCertificates API. If this certificate is manually administered by the user, this field will be empty.@OutputOnly"
"description":"The full paths to user visible Domain Mapping resources that have this certificate mapped. Example: apps/myapp/domainMappings/example.com.This may not represent the full list of mapped domain mappings if the user does not have VIEWER permissions on all of the applications that have this certificate mapped. See domain_mappings_count for a complete count.Only returned by GET or LIST requests when specifically requested by the view=FULL_CERTIFICATE option.@OutputOnly"
},
"expireTime":{
"format":"google-datetime",
"description":"The time when this certificate expires. To update the renewal time on this certificate, upload an SSL certificate with a different expiration time using AuthorizedCertificates.UpdateAuthorizedCertificate.@OutputOnly",
"type":"string"
},
"name":{
"description":"Full path to the AuthorizedCertificate resource in the API. Example: apps/myapp/authorizedCertificates/12345.@OutputOnly",
"type":"string"
},
"domainMappingsCount":{
"format":"int32",
"description":"Aggregate count of the domain mappings with this certificate mapped. This count includes domain mappings on applications for which the user does not have VIEWER permissions.Only returned by GET or LIST requests when specifically requested by the view=FULL_CERTIFICATE option.@OutputOnly",
"type":"integer"
},
"domainNames":{
"description":"Topmost applicable domains of this certificate. This certificate applies to these domains and their subdomains. Example: example.com.@OutputOnly",
"items":{
"type":"string"
},
"type":"array"
},
"id":{
"description":"Relative name of the certificate. This is a unique value autogenerated on AuthorizedCertificate resource creation. Example: 12345.@OutputOnly",
"description":"The standard List next-page token.",
"type":"string"
}
},
"id":"ListLocationsResponse"
},
"ContainerInfo":{
"description":"Docker image that is used to create a container and start a VM instance for the version that you deploy. Only applicable for instances running in the App Engine flexible environment.",
"type":"object",
"properties":{
"image":{
"description":"URI to the hosted container image in Google Container Registry. The URI must be fully qualified and include a tag or digest. Examples: \"gcr.io/my-project/image:tag\" or \"gcr.io/my-project/image@digest\"",
"description":"URL pattern and description of how the URL should be handled. App Engine can handle URLs by executing application code or by serving static files uploaded with the version, such as images, CSS, or JavaScript.",
"description":"Security (HTTPS) enforcement for this URL.",
"type":"string",
"enumDescriptions":[
"Not specified.",
"Both HTTP and HTTPS requests with URLs that match the handler succeed without redirects. The application can examine the request to determine which protocol was used, and respond accordingly.",
"Requests for a URL that match this handler that use HTTPS are automatically redirected to the HTTP equivalent URL.",
"Both HTTP and HTTPS requests with URLs that match the handler succeed without redirects. The application can examine the request to determine which protocol was used and respond accordingly.",
"Requests for a URL that match this handler that do not use HTTPS are automatically redirected to the HTTPS URL with the same path. Query parameters are reserved for the redirect."
"description":"URL prefix. Uses regular expression syntax, which means regexp special characters must be escaped, but should not contain groupings. All URLs that begin with this prefix are handled by this handler, using the portion of the URL after the prefix as part of the file path.",
"description":"Level of login required to access this resource.",
"type":"string",
"enumDescriptions":[
"Not specified. LOGIN_OPTIONAL is assumed.",
"Does not require that the user is signed in.",
"If the user is not signed in, the auth_fail_action is taken. In addition, if the user is not an administrator for the application, they are given an error message regardless of auth_fail_action. If the user is an administrator, the handler proceeds.",
"If the user has signed in, the handler proceeds normally. Otherwise, the auth_fail_action is taken."
"description":"Endpoints service name which is the name of the \"service\" resource in the Service Management API. For example \"myapi.endpoints.myproject.cloud.goog\"",
"description":"Cloud Endpoints (https://cloud.google.com/endpoints) configuration. The Endpoints API Service provides tooling for serving Open API and gRPC endpoints via an NGINX proxy.The fields here refer to the name and configuration id of a \"service\" resource in the Service Management API (https://cloud.google.com/service-management/overview).",
"description":"The error result of the operation in case of failure or cancellation."
},
"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":{
"description":"Properties of the object. Contains field @type with type URL.",
"type":"any"
}
},
"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"
},
"response":{
"additionalProperties":{
"description":"Properties of the object. Contains field @type with type URL.",
"description":"The normal response of the operation in case of success. 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.",
"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 have the format of operations/some/unique/name.",
"description":"Path to the script from the application root directory.",
"type":"string"
},
"login":{
"enumDescriptions":[
"Not specified. LOGIN_OPTIONAL is assumed.",
"Does not require that the user is signed in.",
"If the user is not signed in, the auth_fail_action is taken. In addition, if the user is not an administrator for the application, they are given an error message regardless of auth_fail_action. If the user is an administrator, the handler proceeds.",
"If the user has signed in, the handler proceeds normally. Otherwise, the auth_fail_action is taken."
],
"enum":[
"LOGIN_UNSPECIFIED",
"LOGIN_OPTIONAL",
"LOGIN_ADMIN",
"LOGIN_REQUIRED"
],
"description":"Level of login required to access this resource. Defaults to optional.",
"type":"string"
},
"url":{
"description":"URL to serve the endpoint at.",
"type":"string"
},
"securityLevel":{
"enumDescriptions":[
"Not specified.",
"Both HTTP and HTTPS requests with URLs that match the handler succeed without redirects. The application can examine the request to determine which protocol was used, and respond accordingly.",
"Requests for a URL that match this handler that use HTTPS are automatically redirected to the HTTP equivalent URL.",
"Both HTTP and HTTPS requests with URLs that match the handler succeed without redirects. The application can examine the request to determine which protocol was used and respond accordingly.",
"Requests for a URL that match this handler that do not use HTTPS are automatically redirected to the HTTPS URL with the same path. Query parameters are reserved for the redirect."
],
"enum":[
"SECURE_UNSPECIFIED",
"SECURE_DEFAULT",
"SECURE_NEVER",
"SECURE_OPTIONAL",
"SECURE_ALWAYS"
],
"description":"Security (HTTPS) enforcement for this URL.",
"description":"Whether files should also be uploaded as code data. By default, files declared in static file handlers are uploaded as static data and are only served to end users; they cannot be read by the application. If enabled, uploads are charged against both your code and static data storage resource quotas.",
"type":"boolean"
},
"uploadPathRegex":{
"description":"Regular expression that matches the file paths for all files that should be referenced by this handler.",
"description":"Path to the static files matched by the URL pattern, from the application root directory. The path can refer to text matched in groupings in the URL pattern.",
"description":"MIME type used to serve all files served by this handler.Defaults to file-specific MIME types, which are derived from each file's filename extension."
},
"requireMatchingFile":{
"description":"Whether this handler should match the request if the file referenced by the handler does not exist.",
"type":"boolean"
},
"expiration":{
"format":"google-duration",
"description":"Time a static file served by this handler should be cached by web proxies and browsers.",
"description":"Files served directly to the user for a given URL, such as images, CSS stylesheets, or JavaScript source files. Static file handlers describe which files in the application directory are static files, and which URLs serve them.",
"description":"A service with basic scaling will create an instance when the application receives a request. The instance will be turned down when the app becomes idle. Basic scaling is ideal for work that is intermittent or driven by user activity.",
"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). The error model is designed to be:\nSimple to use and understand for most users\nFlexible enough to meet unexpected needsOverviewThe Status message contains three pieces of data: error code, error message, and error details. The error code should be an enum value of google.rpc.Code, but it may accept additional error codes if needed. The error message should be a developer-facing English message that helps developers understand and resolve the error. If a localized user-facing error message is needed, put the localized message in the error details or localize it in the client. The optional error details may contain arbitrary information about the error. There is a predefined set of error detail types in the package google.rpc that can be used for common error conditions.Language mappingThe Status message is the logical representation of the error model, but it is not necessarily the actual wire format. When the Status message is exposed in different client libraries and different wire protocols, it can be mapped differently. For example, it will likely be mapped to some exceptions in Java, but more likely mapped to some error codes in C.Other usesThe error model and the Status message can be used in a variety of environments, either with or without APIs, to provide a consistent developer experience across different environments.Example uses of this error model include:\nPartial errors. If a service needs to return partial errors to the client, it may embed the Status in the normal response to indicate the partial errors.\nWorkflow errors. A typical workflow has multiple steps. Each step may have a Status message for error reporting.\nBatch operations. If a client uses batch request and batch response, the Status message should be used directly inside batch response, one for each error sub-response.\nAsynchronous operations. If an API call embeds asynchronous operation results in its response, the status of those operations should be represented directly using the Status message.\nLogging. If some API errors are stored in logs, the message Status could be used directly after any stripping needed for security/privacy reasons.",
"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.",
"description":"Whether the serving infrastructure will authenticate and authorize all incoming requests.If true, the oauth2_client_id and oauth2_client_secret fields must be non-empty.",
"description":"OAuth2 client secret to use for the authentication flow.For security reasons, this value cannot be retrieved via the API. Instead, the SHA-256 hash of the value is returned in the oauth2_client_secret_sha256 field.@InputOnly",
"description":"Number of instances to assign to the service at the start. This number can later be altered by using the Modules API (https://cloud.google.com/appengine/docs/python/modules/functions) set_num_instances() function."
"description":"A service with manual scaling runs continuously, allowing you to perform complex initialization and rely on the state of its memory over time.",
"description":"A Service resource is a logical component of an application that can share state and communicate in a secure fashion with other services. For example, an application that handles customer requests might include separate services to handle tasks such as backend data analysis or API requests from mobile devices. Each service has a collection of versions that define a specific set of code used to implement the functionality of that service.",
"description":"IP address or range, defined using CIDR notation, of requests that this rule applies to. You can use the wildcard character \"*\" to match all IPs equivalent to \"0/0\" and \"::/0\" together. Examples: 192.168.1.1 or 192.168.0.0/16 or 2001:db8::/32 or 2001:0db8:0000:0042:0000:8a2e:0370:7334.\u003cp\u003eTruncation will be silently performed on addresses which are not properly truncated. For example, 1.2.3.4/24 is accepted as the same address as 1.2.3.0/24. Similarly, for IPv6, 2001:db8::1/32 is accepted as the same address as 2001:db8::/32.",
"description":"A positive integer between 1, Int32.MaxValue-1 that defines the order of rule evaluation. Rules with the lowest priority are evaluated first.A default rule at priority Int32.MaxValue matches all IPv4 and IPv6 traffic when no previous rule matches. Only the action of this rule can be modified by the user.",
"description":"Boolean value indicating if split health checks should be used instead of the legacy health checks. At an app.yaml level, this means defaulting to 'readiness_check' and 'liveness_check' values instead of 'health_check' ones. Once the legacy 'health_check' behavior is deprecated, and this value is always true, this setting can be removed.",
"description":"ID of the managed AuthorizedCertificate resource currently being provisioned, if applicable. Until the new managed certificate has been successfully provisioned, the previous SSL state will be preserved. Once the provisioning process completes, the certificate_id field will reflect the new managed certificate and this field will be left empty. To remove SSL support while there is still a pending managed certificate, clear the certificate_id field with an UpdateDomainMappingRequest.@OutputOnly",
"SSL support for this domain is configured automatically. The mapped SSL certificate will be automatically renewed.",
"SSL support for this domain is configured manually by the user. Either the domain has no SSL support or a user-obtained SSL certificate has been explictly mapped to this domain."
],
"enum":[
"AUTOMATIC",
"MANUAL"
],
"description":"SSL management type for this domain. If AUTOMATIC, a managed certificate is automatically provisioned. If MANUAL, certificate_id must be manually specified in order to configure SSL for this domain.",
"type":"string"
},
"certificateId":{
"description":"ID of the AuthorizedCertificate resource configuring SSL for the application. Clearing this field will remove SSL support.By default, a managed certificate is automatically created for every domain mapping. To omit SSL support or to configure SSL manually, specify SslManagementType.MANUAL on a CREATE or UPDATE request. You must be authorized to administer the AuthorizedCertificate resource to manually map it to a DomainMapping resource. Example: 12345.",
"description":"Google Cloud Storage bucket that can be used for storing files associated with this application. This bucket is associated with the application and can be used by the gcloud deployment commands.@OutputOnly"
},
"defaultBucket":{
"type":"string",
"description":"Google Cloud Storage bucket that can be used by this application to store content.@OutputOnly"
},
"dispatchRules":{
"description":"HTTP path dispatch rules for requests to the application that do not explicitly target a service or version. Rules are order-dependent. Up to 20 dispatch rules can be supported.@OutputOnly",
"items":{
"$ref":"UrlDispatchRule"
},
"type":"array"
},
"gcrDomain":{
"description":"The Google Container Registry domain used for storing managed build docker images for this application.",
"description":"Identifier of the Application resource. This identifier is equivalent to the project ID of the Google Cloud Platform project where you want to deploy your application. Example: myapp.",
"description":"Cookie expiration policy for this application.",
"type":"string"
},
"locationId":{
"description":"Location from which this application will be run. Application instances will run out of data centers in the chosen location, which is also where all of the application's end user content is stored.Defaults to us-central.Options are:us-central - Central USeurope-west - Western Europeus-east1 - Eastern US",
"type":"string"
},
"servingStatus":{
"enum":[
"UNSPECIFIED",
"SERVING",
"USER_DISABLED",
"SYSTEM_DISABLED"
],
"description":"Serving status of this application.",
"type":"string",
"enumDescriptions":[
"Serving status is unspecified.",
"Application is serving.",
"Application has been disabled by the user.",
"Application has been disabled by the system."
]
},
"defaultHostname":{
"description":"Hostname used to reach this application, as resolved by App Engine.@OutputOnly",
"type":"string"
},
"featureSettings":{
"description":"The feature specific settings to be used in the application.",
"$ref":"FeatureSettings"
},
"authDomain":{
"type":"string",
"description":"Google Apps authentication domain that controls which users can access this application.Defaults to open access for any Google Account."
"description":"Google Cloud Platform sub-network where the virtual machines are created. Specify the short name, not the resource path.If a subnetwork name is specified, a network name will also be required unless it is for the default network.\nIf the network the VM instance is being created in is a Legacy network, then the IP address is allocated from the IPv4Range.\nIf the network the VM instance is being created in is an auto Subnet Mode Network, then only network name should be specified (not the subnetwork_name) and the IP address is created from the IPCidrRange of the subnetwork that exists in that zone for that network.\nIf the network the VM instance is being created in is a custom Subnet Mode Network, then the subnetwork_name must be specified and the IP address is created from the IPCidrRange of the subnetwork.If specified, the subnetwork must exist in the same region as the App Engine flexible environment application.",
"description":"Tag to apply to the VM instance during creation. Only applicable for for App Engine flexible environment versions.",
"type":"string"
},
"forwardedPorts":{
"description":"List of ports, or port pairs, to forward from the virtual machine to the application container. Only applicable for App Engine flexible environment versions.",
"items":{
"type":"string"
},
"type":"array"
},
"name":{
"description":"Google Compute Engine network where the virtual machines are created. Specify the short name, not the resource path.Defaults to default.",