| Index: discovery/googleapis/appengine__v1.json | 
| diff --git a/discovery/googleapis/appengine__v1.json b/discovery/googleapis/appengine__v1.json | 
| index 20a947a9d4e3205846e7194613c499f3afd6d440..0f3f05a7321afae558aa2edfd9094ee3c096e64c 100644 | 
| --- a/discovery/googleapis/appengine__v1.json | 
| +++ b/discovery/googleapis/appengine__v1.json | 
| @@ -2,14 +2,14 @@ | 
| "auth": { | 
| "oauth2": { | 
| "scopes": { | 
| -                "https://www.googleapis.com/auth/cloud-platform": { | 
| -                    "description": "View and manage your data across Google Cloud Platform services" | 
| -                }, | 
| "https://www.googleapis.com/auth/appengine.admin": { | 
| "description": "View and manage your applications deployed on Google App Engine" | 
| }, | 
| "https://www.googleapis.com/auth/cloud-platform.read-only": { | 
| "description": "View your data across Google Cloud Platform services" | 
| +                }, | 
| +                "https://www.googleapis.com/auth/cloud-platform": { | 
| +                    "description": "View and manage your data across Google Cloud Platform services" | 
| } | 
| } | 
| } | 
| @@ -30,21 +30,6 @@ | 
| "ownerDomain": "google.com", | 
| "ownerName": "Google", | 
| "parameters": { | 
| -        "access_token": { | 
| -            "description": "OAuth access token.", | 
| -            "location": "query", | 
| -            "type": "string" | 
| -        }, | 
| -        "key": { | 
| -            "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", | 
| -            "type": "string" | 
| -        }, | 
| -        "quotaUser": { | 
| -            "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", | 
| -            "type": "string" | 
| -        }, | 
| "pp": { | 
| "default": "true", | 
| "description": "Pretty-print response.", | 
| @@ -72,13 +57,13 @@ | 
| "location": "query", | 
| "type": "boolean" | 
| }, | 
| -        "uploadType": { | 
| -            "description": "Legacy upload protocol for media (e.g. \"media\", \"multipart\").", | 
| +        "fields": { | 
| +            "description": "Selector specifying which fields to include in a partial response.", | 
| "location": "query", | 
| "type": "string" | 
| }, | 
| -        "fields": { | 
| -            "description": "Selector specifying which fields to include in a partial response.", | 
| +        "uploadType": { | 
| +            "description": "Legacy upload protocol for media (e.g. \"media\", \"multipart\").", | 
| "location": "query", | 
| "type": "string" | 
| }, | 
| @@ -115,29 +100,27 @@ | 
| ], | 
| "location": "query", | 
| "type": "string" | 
| +        }, | 
| +        "key": { | 
| +            "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", | 
| +            "type": "string" | 
| +        }, | 
| +        "access_token": { | 
| +            "description": "OAuth access token.", | 
| +            "location": "query", | 
| +            "type": "string" | 
| +        }, | 
| +        "quotaUser": { | 
| +            "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", | 
| +            "type": "string" | 
| } | 
| }, | 
| "protocol": "rest", | 
| "resources": { | 
| "apps": { | 
| "methods": { | 
| -                "create": { | 
| -                    "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/).", | 
| -                    "httpMethod": "POST", | 
| -                    "id": "appengine.apps.create", | 
| -                    "parameterOrder": [], | 
| -                    "parameters": {}, | 
| -                    "path": "v1/apps", | 
| -                    "request": { | 
| -                        "$ref": "Application" | 
| -                    }, | 
| -                    "response": { | 
| -                        "$ref": "Operation" | 
| -                    }, | 
| -                    "scopes": [ | 
| -                        "https://www.googleapis.com/auth/cloud-platform" | 
| -                    ] | 
| -                }, | 
| "repair": { | 
| "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.", | 
| "httpMethod": "POST", | 
| @@ -220,86 +203,26 @@ | 
| "https://www.googleapis.com/auth/cloud-platform", | 
| "https://www.googleapis.com/auth/cloud-platform.read-only" | 
| ] | 
| +                }, | 
| +                "create": { | 
| +                    "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/).", | 
| +                    "httpMethod": "POST", | 
| +                    "id": "appengine.apps.create", | 
| +                    "parameterOrder": [], | 
| +                    "parameters": {}, | 
| +                    "path": "v1/apps", | 
| +                    "request": { | 
| +                        "$ref": "Application" | 
| +                    }, | 
| +                    "response": { | 
| +                        "$ref": "Operation" | 
| +                    }, | 
| +                    "scopes": [ | 
| +                        "https://www.googleapis.com/auth/cloud-platform" | 
| +                    ] | 
| } | 
| }, | 
| "resources": { | 
| -                "operations": { | 
| -                    "methods": { | 
| -                        "get": { | 
| -                            "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", | 
| -                            "httpMethod": "GET", | 
| -                            "id": "appengine.apps.operations.get", | 
| -                            "parameterOrder": [ | 
| -                                "appsId", | 
| -                                "operationsId" | 
| -                            ], | 
| -                            "parameters": { | 
| -                                "appsId": { | 
| -                                    "description": "Part of `name`. The name of the operation resource.", | 
| -                                    "location": "path", | 
| -                                    "required": true, | 
| -                                    "type": "string" | 
| -                                }, | 
| -                                "operationsId": { | 
| -                                    "description": "Part of `name`. See documentation of `appsId`.", | 
| -                                    "location": "path", | 
| -                                    "required": true, | 
| -                                    "type": "string" | 
| -                                } | 
| -                            }, | 
| -                            "path": "v1/apps/{appsId}/operations/{operationsId}", | 
| -                            "response": { | 
| -                                "$ref": "Operation" | 
| -                            }, | 
| -                            "scopes": [ | 
| -                                "https://www.googleapis.com/auth/appengine.admin", | 
| -                                "https://www.googleapis.com/auth/cloud-platform", | 
| -                                "https://www.googleapis.com/auth/cloud-platform.read-only" | 
| -                            ] | 
| -                        }, | 
| -                        "list": { | 
| -                            "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.", | 
| -                            "httpMethod": "GET", | 
| -                            "id": "appengine.apps.operations.list", | 
| -                            "parameterOrder": [ | 
| -                                "appsId" | 
| -                            ], | 
| -                            "parameters": { | 
| -                                "pageToken": { | 
| -                                    "description": "The standard list page token.", | 
| -                                    "location": "query", | 
| -                                    "type": "string" | 
| -                                }, | 
| -                                "appsId": { | 
| -                                    "description": "Part of `name`. The name of the operation's parent resource.", | 
| -                                    "location": "path", | 
| -                                    "required": true, | 
| -                                    "type": "string" | 
| -                                }, | 
| -                                "pageSize": { | 
| -                                    "description": "The standard list page size.", | 
| -                                    "format": "int32", | 
| -                                    "location": "query", | 
| -                                    "type": "integer" | 
| -                                }, | 
| -                                "filter": { | 
| -                                    "description": "The standard list filter.", | 
| -                                    "location": "query", | 
| -                                    "type": "string" | 
| -                                } | 
| -                            }, | 
| -                            "path": "v1/apps/{appsId}/operations", | 
| -                            "response": { | 
| -                                "$ref": "ListOperationsResponse" | 
| -                            }, | 
| -                            "scopes": [ | 
| -                                "https://www.googleapis.com/auth/appengine.admin", | 
| -                                "https://www.googleapis.com/auth/cloud-platform", | 
| -                                "https://www.googleapis.com/auth/cloud-platform.read-only" | 
| -                            ] | 
| -                        } | 
| -                    } | 
| -                }, | 
| "locations": { | 
| "methods": { | 
| "get": { | 
| @@ -342,6 +265,12 @@ | 
| "appsId" | 
| ], | 
| "parameters": { | 
| +                                "pageSize": { | 
| +                                    "description": "The standard list page size.", | 
| +                                    "format": "int32", | 
| +                                    "location": "query", | 
| +                                    "type": "integer" | 
| +                                }, | 
| "filter": { | 
| "description": "The standard list filter.", | 
| "location": "query", | 
| @@ -357,12 +286,6 @@ | 
| "location": "path", | 
| "required": true, | 
| "type": "string" | 
| -                                }, | 
| -                                "pageSize": { | 
| -                                    "description": "The standard list page size.", | 
| -                                    "format": "int32", | 
| -                                    "location": "query", | 
| -                                    "type": "integer" | 
| } | 
| }, | 
| "path": "v1/apps/{appsId}/locations", | 
| @@ -418,6 +341,17 @@ | 
| "servicesId" | 
| ], | 
| "parameters": { | 
| +                                "appsId": { | 
| +                                    "description": "Part of `name`. Name of the resource to update. Example: apps/myapp/services/default.", | 
| +                                    "location": "path", | 
| +                                    "required": true, | 
| +                                    "type": "string" | 
| +                                }, | 
| +                                "migrateTraffic": { | 
| +                                    "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/v1/apps.services.versions#inboundservicetype) and automatic scaling (https://cloud.google.com/appengine/docs/admin-api/reference/rest/v1/apps.services.versions#automaticscaling). You must specify the shardBy (https://cloud.google.com/appengine/docs/admin-api/reference/rest/v1/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).", | 
| +                                    "location": "query", | 
| +                                    "type": "boolean" | 
| +                                }, | 
| "updateMask": { | 
| "description": "Standard field mask for the set of fields to be updated.", | 
| "format": "google-fieldmask", | 
| @@ -429,17 +363,6 @@ | 
| "location": "path", | 
| "required": true, | 
| "type": "string" | 
| -                                }, | 
| -                                "appsId": { | 
| -                                    "description": "Part of `name`. Name of the resource to update. Example: apps/myapp/services/default.", | 
| -                                    "location": "path", | 
| -                                    "required": true, | 
| -                                    "type": "string" | 
| -                                }, | 
| -                                "migrateTraffic": { | 
| -                                    "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/v1/apps.services.versions#inboundservicetype) and automatic scaling (https://cloud.google.com/appengine/docs/admin-api/reference/rest/v1/apps.services.versions#automaticscaling). You must specify the shardBy (https://cloud.google.com/appengine/docs/admin-api/reference/rest/v1/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).", | 
| -                                    "location": "query", | 
| -                                    "type": "boolean" | 
| } | 
| }, | 
| "path": "v1/apps/{appsId}/services/{servicesId}", | 
| @@ -572,6 +495,12 @@ | 
| "versionsId" | 
| ], | 
| "parameters": { | 
| +                                        "versionsId": { | 
| +                                            "description": "Part of `name`. See documentation of `appsId`.", | 
| +                                            "location": "path", | 
| +                                            "required": true, | 
| +                                            "type": "string" | 
| +                                        }, | 
| "updateMask": { | 
| "description": "Standard field mask for the set of fields to be updated.", | 
| "format": "google-fieldmask", | 
| @@ -589,12 +518,6 @@ | 
| "location": "path", | 
| "required": true, | 
| "type": "string" | 
| -                                        }, | 
| -                                        "versionsId": { | 
| -                                            "description": "Part of `name`. See documentation of `appsId`.", | 
| -                                            "location": "path", | 
| -                                            "required": true, | 
| -                                            "type": "string" | 
| } | 
| }, | 
| "path": "v1/apps/{appsId}/services/{servicesId}/versions/{versionsId}", | 
| @@ -745,10 +668,10 @@ | 
| "resources": { | 
| "instances": { | 
| "methods": { | 
| -                                        "delete": { | 
| -                                            "description": "Stops a running instance.", | 
| -                                            "httpMethod": "DELETE", | 
| -                                            "id": "appengine.apps.services.versions.instances.delete", | 
| +                                        "debug": { | 
| +                                            "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.", | 
| +                                            "httpMethod": "POST", | 
| +                                            "id": "appengine.apps.services.versions.instances.debug", | 
| "parameterOrder": [ | 
| "appsId", | 
| "servicesId", | 
| @@ -756,12 +679,6 @@ | 
| "instancesId" | 
| ], | 
| "parameters": { | 
| -                                                "versionsId": { | 
| -                                                    "description": "Part of `name`. See documentation of `appsId`.", | 
| -                                                    "location": "path", | 
| -                                                    "required": true, | 
| -                                                    "type": "string" | 
| -                                                }, | 
| "servicesId": { | 
| "description": "Part of `name`. See documentation of `appsId`.", | 
| "location": "path", | 
| @@ -779,9 +696,18 @@ | 
| "location": "path", | 
| "required": true, | 
| "type": "string" | 
| +                                                }, | 
| +                                                "versionsId": { | 
| +                                                    "description": "Part of `name`. See documentation of `appsId`.", | 
| +                                                    "location": "path", | 
| +                                                    "required": true, | 
| +                                                    "type": "string" | 
| } | 
| }, | 
| -                                            "path": "v1/apps/{appsId}/services/{servicesId}/versions/{versionsId}/instances/{instancesId}", | 
| +                                            "path": "v1/apps/{appsId}/services/{servicesId}/versions/{versionsId}/instances/{instancesId}:debug", | 
| +                                            "request": { | 
| +                                                "$ref": "DebugInstanceRequest" | 
| +                                            }, | 
| "response": { | 
| "$ref": "Operation" | 
| }, | 
| @@ -789,10 +715,10 @@ | 
| "https://www.googleapis.com/auth/cloud-platform" | 
| ] | 
| }, | 
| -                                        "get": { | 
| -                                            "description": "Gets instance information.", | 
| -                                            "httpMethod": "GET", | 
| -                                            "id": "appengine.apps.services.versions.instances.get", | 
| +                                        "delete": { | 
| +                                            "description": "Stops a running instance.", | 
| +                                            "httpMethod": "DELETE", | 
| +                                            "id": "appengine.apps.services.versions.instances.delete", | 
| "parameterOrder": [ | 
| "appsId", | 
| "servicesId", | 
| @@ -800,25 +726,25 @@ | 
| "instancesId" | 
| ], | 
| "parameters": { | 
| -                                                "instancesId": { | 
| +                                                "servicesId": { | 
| "description": "Part of `name`. See documentation of `appsId`.", | 
| "location": "path", | 
| "required": true, | 
| "type": "string" | 
| }, | 
| -                                                "appsId": { | 
| -                                                    "description": "Part of `name`. Name of the resource requested. Example: apps/myapp/services/default/versions/v1/instances/instance-1.", | 
| +                                                "instancesId": { | 
| +                                                    "description": "Part of `name`. See documentation of `appsId`.", | 
| "location": "path", | 
| "required": true, | 
| "type": "string" | 
| }, | 
| -                                                "versionsId": { | 
| -                                                    "description": "Part of `name`. See documentation of `appsId`.", | 
| +                                                "appsId": { | 
| +                                                    "description": "Part of `name`. Name of the resource requested. Example: apps/myapp/services/default/versions/v1/instances/instance-1.", | 
| "location": "path", | 
| "required": true, | 
| "type": "string" | 
| }, | 
| -                                                "servicesId": { | 
| +                                                "versionsId": { | 
| "description": "Part of `name`. See documentation of `appsId`.", | 
| "location": "path", | 
| "required": true, | 
| @@ -827,57 +753,51 @@ | 
| }, | 
| "path": "v1/apps/{appsId}/services/{servicesId}/versions/{versionsId}/instances/{instancesId}", | 
| "response": { | 
| -                                                "$ref": "Instance" | 
| +                                                "$ref": "Operation" | 
| }, | 
| "scopes": [ | 
| -                                                "https://www.googleapis.com/auth/appengine.admin", | 
| -                                                "https://www.googleapis.com/auth/cloud-platform", | 
| -                                                "https://www.googleapis.com/auth/cloud-platform.read-only" | 
| +                                                "https://www.googleapis.com/auth/cloud-platform" | 
| ] | 
| }, | 
| -                                        "list": { | 
| -                                            "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).", | 
| +                                        "get": { | 
| +                                            "description": "Gets instance information.", | 
| "httpMethod": "GET", | 
| -                                            "id": "appengine.apps.services.versions.instances.list", | 
| +                                            "id": "appengine.apps.services.versions.instances.get", | 
| "parameterOrder": [ | 
| "appsId", | 
| "servicesId", | 
| -                                                "versionsId" | 
| +                                                "versionsId", | 
| +                                                "instancesId" | 
| ], | 
| "parameters": { | 
| -                                                "pageSize": { | 
| -                                                    "description": "Maximum results to return per page.", | 
| -                                                    "format": "int32", | 
| -                                                    "location": "query", | 
| -                                                    "type": "integer" | 
| -                                                }, | 
| -                                                "versionsId": { | 
| -                                                    "description": "Part of `parent`. See documentation of `appsId`.", | 
| +                                                "servicesId": { | 
| +                                                    "description": "Part of `name`. See documentation of `appsId`.", | 
| "location": "path", | 
| "required": true, | 
| "type": "string" | 
| }, | 
| -                                                "servicesId": { | 
| -                                                    "description": "Part of `parent`. See documentation of `appsId`.", | 
| +                                                "instancesId": { | 
| +                                                    "description": "Part of `name`. See documentation of `appsId`.", | 
| "location": "path", | 
| "required": true, | 
| "type": "string" | 
| }, | 
| -                                                "pageToken": { | 
| -                                                    "description": "Continuation token for fetching the next page of results.", | 
| -                                                    "location": "query", | 
| +                                                "appsId": { | 
| +                                                    "description": "Part of `name`. Name of the resource requested. Example: apps/myapp/services/default/versions/v1/instances/instance-1.", | 
| +                                                    "location": "path", | 
| +                                                    "required": true, | 
| "type": "string" | 
| }, | 
| -                                                "appsId": { | 
| -                                                    "description": "Part of `parent`. Name of the parent Version resource. Example: apps/myapp/services/default/versions/v1.", | 
| +                                                "versionsId": { | 
| +                                                    "description": "Part of `name`. See documentation of `appsId`.", | 
| "location": "path", | 
| "required": true, | 
| "type": "string" | 
| } | 
| }, | 
| -                                            "path": "v1/apps/{appsId}/services/{servicesId}/versions/{versionsId}/instances", | 
| +                                            "path": "v1/apps/{appsId}/services/{servicesId}/versions/{versionsId}/instances/{instancesId}", | 
| "response": { | 
| -                                                "$ref": "ListInstancesResponse" | 
| +                                                "$ref": "Instance" | 
| }, | 
| "scopes": [ | 
| "https://www.googleapis.com/auth/appengine.admin", | 
| @@ -885,51 +805,54 @@ | 
| "https://www.googleapis.com/auth/cloud-platform.read-only" | 
| ] | 
| }, | 
| -                                        "debug": { | 
| -                                            "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.", | 
| -                                            "httpMethod": "POST", | 
| -                                            "id": "appengine.apps.services.versions.instances.debug", | 
| +                                        "list": { | 
| +                                            "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).", | 
| +                                            "httpMethod": "GET", | 
| +                                            "id": "appengine.apps.services.versions.instances.list", | 
| "parameterOrder": [ | 
| "appsId", | 
| "servicesId", | 
| -                                                "versionsId", | 
| -                                                "instancesId" | 
| +                                                "versionsId" | 
| ], | 
| "parameters": { | 
| -                                                "servicesId": { | 
| -                                                    "description": "Part of `name`. See documentation of `appsId`.", | 
| -                                                    "location": "path", | 
| -                                                    "required": true, | 
| +                                                "pageToken": { | 
| +                                                    "description": "Continuation token for fetching the next page of results.", | 
| +                                                    "location": "query", | 
| "type": "string" | 
| }, | 
| -                                                "instancesId": { | 
| -                                                    "description": "Part of `name`. See documentation of `appsId`.", | 
| +                                                "appsId": { | 
| +                                                    "description": "Part of `parent`. Name of the parent Version resource. Example: apps/myapp/services/default/versions/v1.", | 
| "location": "path", | 
| "required": true, | 
| "type": "string" | 
| }, | 
| -                                                "appsId": { | 
| -                                                    "description": "Part of `name`. Name of the resource requested. Example: apps/myapp/services/default/versions/v1/instances/instance-1.", | 
| +                                                "pageSize": { | 
| +                                                    "description": "Maximum results to return per page.", | 
| +                                                    "format": "int32", | 
| +                                                    "location": "query", | 
| +                                                    "type": "integer" | 
| +                                                }, | 
| +                                                "versionsId": { | 
| +                                                    "description": "Part of `parent`. See documentation of `appsId`.", | 
| "location": "path", | 
| "required": true, | 
| "type": "string" | 
| }, | 
| -                                                "versionsId": { | 
| -                                                    "description": "Part of `name`. See documentation of `appsId`.", | 
| +                                                "servicesId": { | 
| +                                                    "description": "Part of `parent`. See documentation of `appsId`.", | 
| "location": "path", | 
| "required": true, | 
| "type": "string" | 
| } | 
| }, | 
| -                                            "path": "v1/apps/{appsId}/services/{servicesId}/versions/{versionsId}/instances/{instancesId}:debug", | 
| -                                            "request": { | 
| -                                                "$ref": "DebugInstanceRequest" | 
| -                                            }, | 
| +                                            "path": "v1/apps/{appsId}/services/{servicesId}/versions/{versionsId}/instances", | 
| "response": { | 
| -                                                "$ref": "Operation" | 
| +                                                "$ref": "ListInstancesResponse" | 
| }, | 
| "scopes": [ | 
| -                                                "https://www.googleapis.com/auth/cloud-platform" | 
| +                                                "https://www.googleapis.com/auth/appengine.admin", | 
| +                                                "https://www.googleapis.com/auth/cloud-platform", | 
| +                                                "https://www.googleapis.com/auth/cloud-platform.read-only" | 
| ] | 
| } | 
| } | 
| @@ -937,504 +860,565 @@ | 
| } | 
| } | 
| } | 
| +                }, | 
| +                "operations": { | 
| +                    "methods": { | 
| +                        "get": { | 
| +                            "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", | 
| +                            "httpMethod": "GET", | 
| +                            "id": "appengine.apps.operations.get", | 
| +                            "parameterOrder": [ | 
| +                                "appsId", | 
| +                                "operationsId" | 
| +                            ], | 
| +                            "parameters": { | 
| +                                "operationsId": { | 
| +                                    "description": "Part of `name`. See documentation of `appsId`.", | 
| +                                    "location": "path", | 
| +                                    "required": true, | 
| +                                    "type": "string" | 
| +                                }, | 
| +                                "appsId": { | 
| +                                    "description": "Part of `name`. The name of the operation resource.", | 
| +                                    "location": "path", | 
| +                                    "required": true, | 
| +                                    "type": "string" | 
| +                                } | 
| +                            }, | 
| +                            "path": "v1/apps/{appsId}/operations/{operationsId}", | 
| +                            "response": { | 
| +                                "$ref": "Operation" | 
| +                            }, | 
| +                            "scopes": [ | 
| +                                "https://www.googleapis.com/auth/appengine.admin", | 
| +                                "https://www.googleapis.com/auth/cloud-platform", | 
| +                                "https://www.googleapis.com/auth/cloud-platform.read-only" | 
| +                            ] | 
| +                        }, | 
| +                        "list": { | 
| +                            "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.", | 
| +                            "httpMethod": "GET", | 
| +                            "id": "appengine.apps.operations.list", | 
| +                            "parameterOrder": [ | 
| +                                "appsId" | 
| +                            ], | 
| +                            "parameters": { | 
| +                                "filter": { | 
| +                                    "description": "The standard list filter.", | 
| +                                    "location": "query", | 
| +                                    "type": "string" | 
| +                                }, | 
| +                                "pageToken": { | 
| +                                    "description": "The standard list page token.", | 
| +                                    "location": "query", | 
| +                                    "type": "string" | 
| +                                }, | 
| +                                "appsId": { | 
| +                                    "description": "Part of `name`. The name of the operation's parent resource.", | 
| +                                    "location": "path", | 
| +                                    "required": true, | 
| +                                    "type": "string" | 
| +                                }, | 
| +                                "pageSize": { | 
| +                                    "description": "The standard list page size.", | 
| +                                    "format": "int32", | 
| +                                    "location": "query", | 
| +                                    "type": "integer" | 
| +                                } | 
| +                            }, | 
| +                            "path": "v1/apps/{appsId}/operations", | 
| +                            "response": { | 
| +                                "$ref": "ListOperationsResponse" | 
| +                            }, | 
| +                            "scopes": [ | 
| +                                "https://www.googleapis.com/auth/appengine.admin", | 
| +                                "https://www.googleapis.com/auth/cloud-platform", | 
| +                                "https://www.googleapis.com/auth/cloud-platform.read-only" | 
| +                            ] | 
| +                        } | 
| +                    } | 
| } | 
| } | 
| } | 
| }, | 
| -    "revision": "20170721", | 
| +    "revision": "20170811", | 
| "rootUrl": "https://appengine.googleapis.com/", | 
| "schemas": { | 
| -        "UrlMap": { | 
| -            "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.", | 
| -            "id": "UrlMap", | 
| +        "DebugInstanceRequest": { | 
| +            "description": "Request message for Instances.DebugInstance.", | 
| +            "id": "DebugInstanceRequest", | 
| "properties": { | 
| -                "script": { | 
| -                    "$ref": "ScriptHandler", | 
| -                    "description": "Executes a script to handle the request that matches this URL pattern." | 
| +                "sshKey": { | 
| +                    "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" | 
| +                } | 
| +            }, | 
| +            "type": "object" | 
| +        }, | 
| +        "OperationMetadataV1Beta5": { | 
| +            "description": "Metadata for the given google.longrunning.Operation.", | 
| +            "id": "OperationMetadataV1Beta5", | 
| +            "properties": { | 
| +                "method": { | 
| +                    "description": "API method name that initiated this operation. Example: google.appengine.v1beta5.Version.CreateVersion.@OutputOnly", | 
| +                    "type": "string" | 
| }, | 
| -                "urlRegex": { | 
| -                    "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.", | 
| +                "insertTime": { | 
| +                    "description": "Timestamp that this operation was created.@OutputOnly", | 
| +                    "format": "google-datetime", | 
| "type": "string" | 
| }, | 
| -                "login": { | 
| -                    "description": "Level of login required to access this resource.", | 
| -                    "enum": [ | 
| -                        "LOGIN_UNSPECIFIED", | 
| -                        "LOGIN_OPTIONAL", | 
| -                        "LOGIN_ADMIN", | 
| -                        "LOGIN_REQUIRED" | 
| -                    ], | 
| -                    "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." | 
| -                    ], | 
| +                "endTime": { | 
| +                    "description": "Timestamp that this operation completed.@OutputOnly", | 
| +                    "format": "google-datetime", | 
| "type": "string" | 
| }, | 
| -                "apiEndpoint": { | 
| -                    "$ref": "ApiEndpointHandler", | 
| -                    "description": "Uses API Endpoints to handle requests." | 
| +                "target": { | 
| +                    "description": "Name of the resource that this operation is acting on. Example: apps/myapp/services/default.@OutputOnly", | 
| +                    "type": "string" | 
| }, | 
| -                "staticFiles": { | 
| -                    "$ref": "StaticFilesHandler", | 
| -                    "description": "Returns the contents of a file, such as an image, as the response." | 
| +                "user": { | 
| +                    "description": "User who requested this operation.@OutputOnly", | 
| +                    "type": "string" | 
| +                } | 
| +            }, | 
| +            "type": "object" | 
| +        }, | 
| +        "Version": { | 
| +            "description": "A Version resource is a specific set of source code and configuration files that are deployed into a service.", | 
| +            "id": "Version", | 
| +            "properties": { | 
| +                "automaticScaling": { | 
| +                    "$ref": "AutomaticScaling", | 
| +                    "description": "Automatic scaling is based on request rate, response latencies, and other application metrics." | 
| }, | 
| -                "redirectHttpResponseCode": { | 
| -                    "description": "30x code to use when performing redirects for the secure field. Defaults to 302.", | 
| -                    "enum": [ | 
| -                        "REDIRECT_HTTP_RESPONSE_CODE_UNSPECIFIED", | 
| -                        "REDIRECT_HTTP_RESPONSE_CODE_301", | 
| -                        "REDIRECT_HTTP_RESPONSE_CODE_302", | 
| -                        "REDIRECT_HTTP_RESPONSE_CODE_303", | 
| -                        "REDIRECT_HTTP_RESPONSE_CODE_307" | 
| -                    ], | 
| -                    "enumDescriptions": [ | 
| -                        "Not specified. 302 is assumed.", | 
| -                        "301 Moved Permanently code.", | 
| -                        "302 Moved Temporarily code.", | 
| -                        "303 See Other code.", | 
| -                        "307 Temporary Redirect code." | 
| -                    ], | 
| +                "diskUsageBytes": { | 
| +                    "description": "Total size in bytes of all the files that are included in this version and curerntly hosted on the App Engine disk.@OutputOnly", | 
| +                    "format": "int64", | 
| "type": "string" | 
| }, | 
| -                "securityLevel": { | 
| -                    "description": "Security (HTTPS) enforcement for this URL.", | 
| -                    "enum": [ | 
| -                        "SECURE_UNSPECIFIED", | 
| -                        "SECURE_DEFAULT", | 
| -                        "SECURE_NEVER", | 
| -                        "SECURE_OPTIONAL", | 
| -                        "SECURE_ALWAYS" | 
| -                    ], | 
| -                    "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." | 
| -                    ], | 
| -                    "type": "string" | 
| +                "healthCheck": { | 
| +                    "$ref": "HealthCheck", | 
| +                    "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." | 
| }, | 
| -                "authFailAction": { | 
| -                    "description": "Action to take when users access resources that require authentication. Defaults to redirect.", | 
| -                    "enum": [ | 
| -                        "AUTH_FAIL_ACTION_UNSPECIFIED", | 
| -                        "AUTH_FAIL_ACTION_REDIRECT", | 
| -                        "AUTH_FAIL_ACTION_UNAUTHORIZED" | 
| -                    ], | 
| -                    "enumDescriptions": [ | 
| -                        "Not specified. AUTH_FAIL_ACTION_REDIRECT is assumed.", | 
| -                        "Redirects user to \"accounts.google.com\". The user is redirected back to the application URL after signing in or creating an account.", | 
| -                        "Rejects request with a 401 HTTP status code and an error message." | 
| -                    ], | 
| -                    "type": "string" | 
| -                } | 
| -            }, | 
| -            "type": "object" | 
| -        }, | 
| -        "EndpointsApiService": { | 
| -            "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).", | 
| -            "id": "EndpointsApiService", | 
| -            "properties": { | 
| -                "configId": { | 
| -                    "description": "Endpoints service configuration id as specified by the Service Management API. For example \"2016-09-19r1\"", | 
| -                    "type": "string" | 
| +                "threadsafe": { | 
| +                    "description": "Whether multiple requests can be dispatched to this version at once.", | 
| +                    "type": "boolean" | 
| }, | 
| -                "name": { | 
| -                    "description": "Endpoints service name which is the name of the \"service\" resource in the Service Management API. For example \"myapi.endpoints.myproject.cloud.goog\"", | 
| -                    "type": "string" | 
| -                } | 
| -            }, | 
| -            "type": "object" | 
| -        }, | 
| -        "Operation": { | 
| -            "description": "This resource represents a long-running operation that is the result of a network API call.", | 
| -            "id": "Operation", | 
| -            "properties": { | 
| -                "response": { | 
| -                    "additionalProperties": { | 
| -                        "description": "Properties of the object. Contains field @type with type URL.", | 
| -                        "type": "any" | 
| -                    }, | 
| -                    "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.", | 
| -                    "type": "object" | 
| +                "readinessCheck": { | 
| +                    "$ref": "ReadinessCheck", | 
| +                    "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." | 
| +                }, | 
| +                "manualScaling": { | 
| +                    "$ref": "ManualScaling", | 
| +                    "description": "A service with manual scaling runs continuously, allowing you to perform complex initialization and rely on the state of its memory over time." | 
| }, | 
| "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 have the format of operations/some/unique/name.", | 
| +                    "description": "Full path to the Version resource in the API. Example: apps/myapp/services/default/versions/v1.@OutputOnly", | 
| "type": "string" | 
| }, | 
| -                "error": { | 
| -                    "$ref": "Status", | 
| -                    "description": "The error result of the operation in case of failure or cancellation." | 
| +                "apiConfig": { | 
| +                    "$ref": "ApiConfigHandler", | 
| +                    "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." | 
| }, | 
| -                "metadata": { | 
| -                    "additionalProperties": { | 
| -                        "description": "Properties of the object. Contains field @type with type URL.", | 
| -                        "type": "any" | 
| -                    }, | 
| -                    "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" | 
| +                "endpointsApiService": { | 
| +                    "$ref": "EndpointsApiService", | 
| +                    "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." | 
| }, | 
| -                "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.", | 
| +                "vm": { | 
| +                    "description": "Whether to deploy this version in a container on a virtual machine.", | 
| "type": "boolean" | 
| -                } | 
| -            }, | 
| -            "type": "object" | 
| -        }, | 
| -        "ApiConfigHandler": { | 
| -            "description": "Google Cloud Endpoints (https://cloud.google.com/appengine/docs/python/endpoints/) configuration for API handlers.", | 
| -            "id": "ApiConfigHandler", | 
| -            "properties": { | 
| -                "login": { | 
| -                    "description": "Level of login required to access this resource. Defaults to optional.", | 
| -                    "enum": [ | 
| -                        "LOGIN_UNSPECIFIED", | 
| -                        "LOGIN_OPTIONAL", | 
| -                        "LOGIN_ADMIN", | 
| -                        "LOGIN_REQUIRED" | 
| -                    ], | 
| -                    "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." | 
| -                    ], | 
| +                }, | 
| +                "versionUrl": { | 
| +                    "description": "Serving URL for this version. Example: \"https://myversion-dot-myservice-dot-myapp.appspot.com\"@OutputOnly", | 
| "type": "string" | 
| }, | 
| -                "url": { | 
| -                    "description": "URL to serve the endpoint at.", | 
| +                "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.", | 
| "type": "string" | 
| }, | 
| -                "securityLevel": { | 
| -                    "description": "Security (HTTPS) enforcement for this URL.", | 
| +                "servingStatus": { | 
| +                    "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.", | 
| "enum": [ | 
| -                        "SECURE_UNSPECIFIED", | 
| -                        "SECURE_DEFAULT", | 
| -                        "SECURE_NEVER", | 
| -                        "SECURE_OPTIONAL", | 
| -                        "SECURE_ALWAYS" | 
| +                        "SERVING_STATUS_UNSPECIFIED", | 
| +                        "SERVING", | 
| +                        "STOPPED" | 
| ], | 
| "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." | 
| +                        "Currently serving. Instances are created according to the scaling settings of the version.", | 
| +                        "Disabled. No instances will be created and the scaling settings are ignored until the state of the version changes to SERVING." | 
| ], | 
| "type": "string" | 
| }, | 
| -                "authFailAction": { | 
| -                    "description": "Action to take when users access resources that require authentication. Defaults to redirect.", | 
| -                    "enum": [ | 
| -                        "AUTH_FAIL_ACTION_UNSPECIFIED", | 
| -                        "AUTH_FAIL_ACTION_REDIRECT", | 
| -                        "AUTH_FAIL_ACTION_UNAUTHORIZED" | 
| -                    ], | 
| -                    "enumDescriptions": [ | 
| -                        "Not specified. AUTH_FAIL_ACTION_REDIRECT is assumed.", | 
| -                        "Redirects user to \"accounts.google.com\". The user is redirected back to the application URL after signing in or creating an account.", | 
| -                        "Rejects request with a 401 HTTP status code and an error message." | 
| -                    ], | 
| +                "deployment": { | 
| +                    "$ref": "Deployment", | 
| +                    "description": "Code and application artifacts that make up this version.Only returned in GET requests if view=FULL is set." | 
| +                }, | 
| +                "runtimeApiVersion": { | 
| +                    "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/<language>/config/appref", | 
| "type": "string" | 
| }, | 
| -                "script": { | 
| -                    "description": "Path to the script from the application root directory.", | 
| +                "createTime": { | 
| +                    "description": "Time that this version was created.@OutputOnly", | 
| +                    "format": "google-datetime", | 
| "type": "string" | 
| -                } | 
| -            }, | 
| -            "type": "object" | 
| -        }, | 
| -        "StaticFilesHandler": { | 
| -            "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.", | 
| -            "id": "StaticFilesHandler", | 
| -            "properties": { | 
| -                "httpHeaders": { | 
| -                    "additionalProperties": { | 
| +                }, | 
| +                "resources": { | 
| +                    "$ref": "Resources", | 
| +                    "description": "Machine resources for this version. Only applicable for VM runtimes." | 
| +                }, | 
| +                "inboundServices": { | 
| +                    "description": "Before an application can receive email or XMPP messages, the application must be configured to enable the service.", | 
| +                    "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." | 
| +                    ], | 
| +                    "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" | 
| }, | 
| -                    "description": "HTTP headers to use for all responses from these URLs.", | 
| -                    "type": "object" | 
| +                    "type": "array" | 
| }, | 
| -                "applicationReadable": { | 
| -                    "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" | 
| +                "errorHandlers": { | 
| +                    "description": "Custom static error pages. Limited to 10KB per page.Only returned in GET requests if view=FULL is set.", | 
| +                    "items": { | 
| +                        "$ref": "ErrorHandler" | 
| +                    }, | 
| +                    "type": "array" | 
| }, | 
| -                "uploadPathRegex": { | 
| -                    "description": "Regular expression that matches the file paths for all files that should be referenced by this handler.", | 
| +                "defaultExpiration": { | 
| +                    "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/v1/apps.services.versions#staticfileshandler) does not specify its own expiration time.Only returned in GET requests if view=FULL is set.", | 
| +                    "format": "google-duration", | 
| "type": "string" | 
| }, | 
| -                "path": { | 
| -                    "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.", | 
| +                "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.", | 
| "type": "string" | 
| }, | 
| -                "mimeType": { | 
| -                    "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.", | 
| +                "basicScaling": { | 
| +                    "$ref": "BasicScaling", | 
| +                    "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." | 
| +                }, | 
| +                "runtime": { | 
| +                    "description": "Desired runtime. Example: python27.", | 
| "type": "string" | 
| }, | 
| -                "requireMatchingFile": { | 
| -                    "description": "Whether this handler should match the request if the file referenced by the handler does not exist.", | 
| -                    "type": "boolean" | 
| +                "createdBy": { | 
| +                    "description": "Email address of the user who created this version.@OutputOnly", | 
| +                    "type": "string" | 
| }, | 
| -                "expiration": { | 
| -                    "description": "Time a static file served by this handler should be cached by web proxies and browsers.", | 
| -                    "format": "google-duration", | 
| +                "id": { | 
| +                    "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-\".", | 
| "type": "string" | 
| -                } | 
| -            }, | 
| -            "type": "object" | 
| -        }, | 
| -        "DiskUtilization": { | 
| -            "description": "Target scaling by disk usage. Only applicable for VM runtimes.", | 
| -            "id": "DiskUtilization", | 
| -            "properties": { | 
| -                "targetWriteBytesPerSecond": { | 
| -                    "description": "Target bytes written per second.", | 
| -                    "format": "int32", | 
| -                    "type": "integer" | 
| }, | 
| -                "targetReadOpsPerSecond": { | 
| -                    "description": "Target ops read per seconds.", | 
| -                    "format": "int32", | 
| -                    "type": "integer" | 
| +                "envVariables": { | 
| +                    "additionalProperties": { | 
| +                        "type": "string" | 
| +                    }, | 
| +                    "description": "Environment variables available to the application.Only returned in GET requests if view=FULL is set.", | 
| +                    "type": "object" | 
| }, | 
| -                "targetReadBytesPerSecond": { | 
| -                    "description": "Target bytes read per second.", | 
| -                    "format": "int32", | 
| -                    "type": "integer" | 
| +                "livenessCheck": { | 
| +                    "$ref": "LivenessCheck", | 
| +                    "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." | 
| }, | 
| -                "targetWriteOpsPerSecond": { | 
| -                    "description": "Target ops written per second.", | 
| -                    "format": "int32", | 
| -                    "type": "integer" | 
| -                } | 
| -            }, | 
| -            "type": "object" | 
| -        }, | 
| -        "BasicScaling": { | 
| -            "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.", | 
| -            "id": "BasicScaling", | 
| -            "properties": { | 
| -                "idleTimeout": { | 
| -                    "description": "Duration of time after the last request that an instance must wait before the instance is shut down.", | 
| -                    "format": "google-duration", | 
| +                "network": { | 
| +                    "$ref": "Network", | 
| +                    "description": "Extra network settings. Only applicable for App Engine flexible environment versions." | 
| +                }, | 
| +                "betaSettings": { | 
| +                    "additionalProperties": { | 
| +                        "type": "string" | 
| +                    }, | 
| +                    "description": "Metadata settings that are supplied to this version to enable beta runtime features.", | 
| +                    "type": "object" | 
| +                }, | 
| +                "env": { | 
| +                    "description": "App Engine execution environment for this version.Defaults to standard.", | 
| "type": "string" | 
| }, | 
| -                "maxInstances": { | 
| -                    "description": "Maximum number of instances to create for this version.", | 
| -                    "format": "int32", | 
| -                    "type": "integer" | 
| +                "handlers": { | 
| +                    "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.", | 
| +                    "items": { | 
| +                        "$ref": "UrlMap" | 
| +                    }, | 
| +                    "type": "array" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "CpuUtilization": { | 
| -            "description": "Target scaling by CPU usage.", | 
| -            "id": "CpuUtilization", | 
| +        "RepairApplicationRequest": { | 
| +            "description": "Request message for 'Applications.RepairApplication'.", | 
| +            "id": "RepairApplicationRequest", | 
| +            "properties": {}, | 
| +            "type": "object" | 
| +        }, | 
| +        "ScriptHandler": { | 
| +            "description": "Executes a script to handle the request that matches the URL pattern.", | 
| +            "id": "ScriptHandler", | 
| "properties": { | 
| -                "aggregationWindowLength": { | 
| -                    "description": "Period of time over which CPU utilization is calculated.", | 
| -                    "format": "google-duration", | 
| +                "scriptPath": { | 
| +                    "description": "Path to the script from the application root directory.", | 
| "type": "string" | 
| -                }, | 
| -                "targetUtilization": { | 
| -                    "description": "Target CPU utilization ratio to maintain when scaling. Must be between 0 and 1.", | 
| -                    "format": "double", | 
| -                    "type": "number" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "IdentityAwareProxy": { | 
| -            "description": "Identity-Aware Proxy", | 
| -            "id": "IdentityAwareProxy", | 
| +        "FileInfo": { | 
| +            "description": "Single source file that is part of the version to be deployed. Each source file that is deployed must be specified separately.", | 
| +            "id": "FileInfo", | 
| "properties": { | 
| -                "oauth2ClientSecret": { | 
| -                    "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", | 
| +                "sha1Sum": { | 
| +                    "description": "The SHA1 hash of the file, in hex.", | 
| "type": "string" | 
| }, | 
| -                "oauth2ClientId": { | 
| -                    "description": "OAuth2 client ID to use for the authentication flow.", | 
| +                "mimeType": { | 
| +                    "description": "The MIME type of the file.Defaults to the value from Google Cloud Storage.", | 
| "type": "string" | 
| }, | 
| -                "oauth2ClientSecretSha256": { | 
| -                    "description": "Hex-encoded SHA-256 hash of the client secret.@OutputOnly", | 
| +                "sourceUrl": { | 
| +                    "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/<bucket>/<object>'.", | 
| "type": "string" | 
| -                }, | 
| -                "enabled": { | 
| -                    "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.", | 
| -                    "type": "boolean" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "Status": { | 
| -            "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.", | 
| -            "id": "Status", | 
| +        "OperationMetadataExperimental": { | 
| +            "description": "Metadata for the given google.longrunning.Operation.", | 
| +            "id": "OperationMetadataExperimental", | 
| "properties": { | 
| -                "message": { | 
| -                    "description": "A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client.", | 
| +                "insertTime": { | 
| +                    "description": "Time that this operation was created.@OutputOnly", | 
| +                    "format": "google-datetime", | 
| "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.", | 
| -                    "items": { | 
| -                        "additionalProperties": { | 
| -                            "description": "Properties of the object. Contains field @type with type URL.", | 
| -                            "type": "any" | 
| -                        }, | 
| -                        "type": "object" | 
| -                    }, | 
| -                    "type": "array" | 
| +                "endTime": { | 
| +                    "description": "Time that this operation completed.@OutputOnly", | 
| +                    "format": "google-datetime", | 
| +                    "type": "string" | 
| }, | 
| -                "code": { | 
| -                    "description": "The status code, which should be an enum value of google.rpc.Code.", | 
| -                    "format": "int32", | 
| -                    "type": "integer" | 
| -                } | 
| -            }, | 
| -            "type": "object" | 
| -        }, | 
| -        "ManualScaling": { | 
| -            "description": "A service with manual scaling runs continuously, allowing you to perform complex initialization and rely on the state of its memory over time.", | 
| -            "id": "ManualScaling", | 
| -            "properties": { | 
| -                "instances": { | 
| -                    "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.", | 
| -                    "format": "int32", | 
| -                    "type": "integer" | 
| +                "target": { | 
| +                    "description": "Name of the resource that this operation is acting on. Example: apps/myapp/customDomains/example.com.@OutputOnly", | 
| +                    "type": "string" | 
| +                }, | 
| +                "user": { | 
| +                    "description": "User who requested this operation.@OutputOnly", | 
| +                    "type": "string" | 
| +                }, | 
| +                "method": { | 
| +                    "description": "API method that initiated this operation. Example: google.appengine.experimental.CustomDomains.CreateCustomDomain.@OutputOnly", | 
| +                    "type": "string" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "LocationMetadata": { | 
| -            "description": "Metadata for the given google.cloud.location.Location.", | 
| -            "id": "LocationMetadata", | 
| +        "TrafficSplit": { | 
| +            "description": "Traffic routing configuration for versions within a single service. Traffic splits define how traffic directed to the service is assigned to versions.", | 
| +            "id": "TrafficSplit", | 
| "properties": { | 
| -                "flexibleEnvironmentAvailable": { | 
| -                    "description": "App Engine Flexible Environment is available in the given location.@OutputOnly", | 
| -                    "type": "boolean" | 
| +                "allocations": { | 
| +                    "additionalProperties": { | 
| +                        "format": "double", | 
| +                        "type": "number" | 
| +                    }, | 
| +                    "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" | 
| }, | 
| -                "standardEnvironmentAvailable": { | 
| -                    "description": "App Engine Standard Environment is available in the given location.@OutputOnly", | 
| -                    "type": "boolean" | 
| +                "shardBy": { | 
| +                    "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.", | 
| +                    "enum": [ | 
| +                        "UNSPECIFIED", | 
| +                        "COOKIE", | 
| +                        "IP", | 
| +                        "RANDOM" | 
| +                    ], | 
| +                    "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." | 
| +                    ], | 
| +                    "type": "string" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "Service": { | 
| -            "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.", | 
| -            "id": "Service", | 
| +        "OperationMetadataV1Beta": { | 
| +            "description": "Metadata for the given google.longrunning.Operation.", | 
| +            "id": "OperationMetadataV1Beta", | 
| "properties": { | 
| -                "name": { | 
| -                    "description": "Full path to the Service resource in the API. Example: apps/myapp/services/default.@OutputOnly", | 
| +                "ephemeralMessage": { | 
| +                    "description": "Ephemeral message that may change every time the operation is polled. @OutputOnly", | 
| "type": "string" | 
| }, | 
| -                "split": { | 
| -                    "$ref": "TrafficSplit", | 
| -                    "description": "Mapping that defines fractional HTTP traffic diversion to different versions within the service." | 
| +                "method": { | 
| +                    "description": "API method that initiated this operation. Example: google.appengine.v1beta.Versions.CreateVersion.@OutputOnly", | 
| +                    "type": "string" | 
| }, | 
| -                "id": { | 
| -                    "description": "Relative name of the service within the application. Example: default.@OutputOnly", | 
| +                "endTime": { | 
| +                    "description": "Time that this operation completed.@OutputOnly", | 
| +                    "format": "google-datetime", | 
| +                    "type": "string" | 
| +                }, | 
| +                "warning": { | 
| +                    "description": "Durable messages that persist on every operation poll. @OutputOnly", | 
| +                    "items": { | 
| +                        "type": "string" | 
| +                    }, | 
| +                    "type": "array" | 
| +                }, | 
| +                "insertTime": { | 
| +                    "description": "Time that this operation was created.@OutputOnly", | 
| +                    "format": "google-datetime", | 
| +                    "type": "string" | 
| +                }, | 
| +                "user": { | 
| +                    "description": "User who requested this operation.@OutputOnly", | 
| +                    "type": "string" | 
| +                }, | 
| +                "target": { | 
| +                    "description": "Name of the resource that this operation is acting on. Example: apps/myapp/services/default.@OutputOnly", | 
| "type": "string" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "ListOperationsResponse": { | 
| -            "description": "The response message for Operations.ListOperations.", | 
| -            "id": "ListOperationsResponse", | 
| +        "ListServicesResponse": { | 
| +            "description": "Response message for Services.ListServices.", | 
| +            "id": "ListServicesResponse", | 
| "properties": { | 
| "nextPageToken": { | 
| -                    "description": "The standard List next-page token.", | 
| +                    "description": "Continuation token for fetching the next page of results.", | 
| "type": "string" | 
| }, | 
| -                "operations": { | 
| -                    "description": "A list of operations that matches the specified filter in the request.", | 
| +                "services": { | 
| +                    "description": "The services belonging to the requested application.", | 
| "items": { | 
| -                        "$ref": "Operation" | 
| +                        "$ref": "Service" | 
| }, | 
| "type": "array" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "OperationMetadata": { | 
| -            "description": "Metadata for the given google.longrunning.Operation.", | 
| -            "id": "OperationMetadata", | 
| +        "Deployment": { | 
| +            "description": "Code and application artifacts used to deploy a version to App Engine.", | 
| +            "id": "Deployment", | 
| "properties": { | 
| -                "endTime": { | 
| -                    "description": "Timestamp that this operation completed.@OutputOnly", | 
| -                    "format": "google-datetime", | 
| -                    "type": "string" | 
| +                "files": { | 
| +                    "additionalProperties": { | 
| +                        "$ref": "FileInfo" | 
| +                    }, | 
| +                    "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.", | 
| +                    "type": "object" | 
| }, | 
| -                "operationType": { | 
| -                    "description": "Type of this operation. Deprecated, use method field instead. Example: \"create_version\".@OutputOnly", | 
| -                    "type": "string" | 
| +                "zip": { | 
| +                    "$ref": "ZipInfo", | 
| +                    "description": "The zip file for this deployment, if this is a zip deployment." | 
| }, | 
| -                "insertTime": { | 
| -                    "description": "Timestamp that this operation was created.@OutputOnly", | 
| -                    "format": "google-datetime", | 
| -                    "type": "string" | 
| +                "container": { | 
| +                    "$ref": "ContainerInfo", | 
| +                    "description": "The Docker image for the container that runs the version. Only applicable for instances running in the App Engine flexible environment." | 
| +                } | 
| +            }, | 
| +            "type": "object" | 
| +        }, | 
| +        "Resources": { | 
| +            "description": "Machine resources for a version.", | 
| +            "id": "Resources", | 
| +            "properties": { | 
| +                "memoryGb": { | 
| +                    "description": "Memory (GB) needed.", | 
| +                    "format": "double", | 
| +                    "type": "number" | 
| }, | 
| -                "user": { | 
| -                    "description": "User who requested this operation.@OutputOnly", | 
| -                    "type": "string" | 
| +                "cpu": { | 
| +                    "description": "Number of CPU cores needed.", | 
| +                    "format": "double", | 
| +                    "type": "number" | 
| }, | 
| -                "target": { | 
| -                    "description": "Name of the resource that this operation is acting on. Example: apps/myapp/modules/default.@OutputOnly", | 
| +                "volumes": { | 
| +                    "description": "User specified volumes.", | 
| +                    "items": { | 
| +                        "$ref": "Volume" | 
| +                    }, | 
| +                    "type": "array" | 
| +                }, | 
| +                "diskGb": { | 
| +                    "description": "Disk size (GB) needed.", | 
| +                    "format": "double", | 
| +                    "type": "number" | 
| +                } | 
| +            }, | 
| +            "type": "object" | 
| +        }, | 
| +        "Volume": { | 
| +            "description": "Volumes mounted within the app container. Only applicable for VM runtimes.", | 
| +            "id": "Volume", | 
| +            "properties": { | 
| +                "volumeType": { | 
| +                    "description": "Underlying volume type, e.g. 'tmpfs'.", | 
| "type": "string" | 
| }, | 
| -                "method": { | 
| -                    "description": "API method that initiated this operation. Example: google.appengine.v1beta4.Version.CreateVersion.@OutputOnly", | 
| +                "sizeGb": { | 
| +                    "description": "Volume size in gigabytes.", | 
| +                    "format": "double", | 
| +                    "type": "number" | 
| +                }, | 
| +                "name": { | 
| +                    "description": "Unique name for the volume.", | 
| "type": "string" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "ErrorHandler": { | 
| -            "description": "Custom static error page to be served when an error occurs.", | 
| -            "id": "ErrorHandler", | 
| +        "ListInstancesResponse": { | 
| +            "description": "Response message for Instances.ListInstances.", | 
| +            "id": "ListInstancesResponse", | 
| "properties": { | 
| -                "mimeType": { | 
| -                    "description": "MIME type of file. Defaults to text/html.", | 
| -                    "type": "string" | 
| -                }, | 
| -                "errorCode": { | 
| -                    "description": "Error condition this handler applies to.", | 
| -                    "enum": [ | 
| -                        "ERROR_CODE_UNSPECIFIED", | 
| -                        "ERROR_CODE_DEFAULT", | 
| -                        "ERROR_CODE_OVER_QUOTA", | 
| -                        "ERROR_CODE_DOS_API_DENIAL", | 
| -                        "ERROR_CODE_TIMEOUT" | 
| -                    ], | 
| -                    "enumDescriptions": [ | 
| -                        "Not specified. ERROR_CODE_DEFAULT is assumed.", | 
| -                        "All other error types.", | 
| -                        "Application has exceeded a resource quota.", | 
| -                        "Client blocked by the application's Denial of Service protection configuration.", | 
| -                        "Deadline reached before the application responds." | 
| -                    ], | 
| -                    "type": "string" | 
| +                "instances": { | 
| +                    "description": "The instances belonging to the requested version.", | 
| +                    "items": { | 
| +                        "$ref": "Instance" | 
| +                    }, | 
| +                    "type": "array" | 
| }, | 
| -                "staticFile": { | 
| -                    "description": "Static file content to be served for this error.", | 
| +                "nextPageToken": { | 
| +                    "description": "Continuation token for fetching the next page of results.", | 
| "type": "string" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "OperationMetadataV1": { | 
| +        "OperationMetadataV1Alpha": { | 
| "description": "Metadata for the given google.longrunning.Operation.", | 
| -            "id": "OperationMetadataV1", | 
| +            "id": "OperationMetadataV1Alpha", | 
| "properties": { | 
| -                "endTime": { | 
| -                    "description": "Time that this operation completed.@OutputOnly", | 
| -                    "format": "google-datetime", | 
| -                    "type": "string" | 
| -                }, | 
| "warning": { | 
| "description": "Durable messages that persist on every operation poll. @OutputOnly", | 
| "items": { | 
| @@ -1447,717 +1431,704 @@ | 
| "format": "google-datetime", | 
| "type": "string" | 
| }, | 
| -                "user": { | 
| -                    "description": "User who requested this operation.@OutputOnly", | 
| -                    "type": "string" | 
| -                }, | 
| "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.v1.Versions.CreateVersion.@OutputOnly", | 
| +                    "description": "API method that initiated this operation. Example: google.appengine.v1alpha.Versions.CreateVersion.@OutputOnly", | 
| +                    "type": "string" | 
| +                }, | 
| +                "endTime": { | 
| +                    "description": "Time that this operation completed.@OutputOnly", | 
| +                    "format": "google-datetime", | 
| "type": "string" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "Application": { | 
| -            "description": "An Application resource contains the top-level configuration of an App Engine application. Next tag: 20", | 
| -            "id": "Application", | 
| +        "UrlDispatchRule": { | 
| +            "description": "Rules to match an HTTP request and dispatch that request to a service.", | 
| +            "id": "UrlDispatchRule", | 
| "properties": { | 
| -                "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": { | 
| -                    "description": "Serving status of this application.", | 
| -                    "enum": [ | 
| -                        "UNSPECIFIED", | 
| -                        "SERVING", | 
| -                        "USER_DISABLED", | 
| -                        "SYSTEM_DISABLED" | 
| -                    ], | 
| -                    "enumDescriptions": [ | 
| -                        "Serving status is unspecified.", | 
| -                        "Application is serving.", | 
| -                        "Application has been disabled by the user.", | 
| -                        "Application has been disabled by the system." | 
| -                    ], | 
| -                    "type": "string" | 
| -                }, | 
| -                "defaultHostname": { | 
| -                    "description": "Hostname used to reach this application, as resolved by App Engine.@OutputOnly", | 
| -                    "type": "string" | 
| -                }, | 
| -                "authDomain": { | 
| -                    "description": "Google Apps authentication domain that controls which users can access this application.Defaults to open access for any Google Account.", | 
| -                    "type": "string" | 
| -                }, | 
| -                "iap": { | 
| -                    "$ref": "IdentityAwareProxy" | 
| -                }, | 
| -                "codeBucket": { | 
| -                    "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", | 
| -                    "type": "string" | 
| -                }, | 
| -                "defaultBucket": { | 
| -                    "description": "Google Cloud Storage bucket that can be used by this application to store content.@OutputOnly", | 
| -                    "type": "string" | 
| -                }, | 
| -                "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.", | 
| -                    "type": "string" | 
| -                }, | 
| -                "name": { | 
| -                    "description": "Full path to the Application resource in the API. Example: apps/myapp.@OutputOnly", | 
| +                "service": { | 
| +                    "description": "Resource ID of a service in this application that should serve the matched request. The service must already exist. Example: default.", | 
| "type": "string" | 
| }, | 
| -                "defaultCookieExpiration": { | 
| -                    "description": "Cookie expiration policy for this application.", | 
| -                    "format": "google-duration", | 
| +                "domain": { | 
| +                    "description": "Domain name to match against. The wildcard \"*\" is supported if specified before a period: \"*.\".Defaults to matching all domains: \"*\".", | 
| "type": "string" | 
| }, | 
| -                "id": { | 
| -                    "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.", | 
| +                "path": { | 
| +                    "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.", | 
| "type": "string" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "Network": { | 
| -            "description": "Extra network settings. Only applicable for VM runtimes.", | 
| -            "id": "Network", | 
| +        "ListVersionsResponse": { | 
| +            "description": "Response message for Versions.ListVersions.", | 
| +            "id": "ListVersionsResponse", | 
| "properties": { | 
| -                "subnetworkName": { | 
| -                    "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 Flex app.", | 
| -                    "type": "string" | 
| -                }, | 
| -                "instanceTag": { | 
| -                    "description": "Tag to apply to the VM instance during creation.", | 
| -                    "type": "string" | 
| -                }, | 
| -                "forwardedPorts": { | 
| -                    "description": "List of ports, or port pairs, to forward from the virtual machine to the application container.", | 
| +                "versions": { | 
| +                    "description": "The versions belonging to the requested service.", | 
| "items": { | 
| -                        "type": "string" | 
| +                        "$ref": "Version" | 
| }, | 
| "type": "array" | 
| }, | 
| -                "name": { | 
| -                    "description": "Google Cloud Platform network where the virtual machines are created. Specify the short name, not the resource path.Defaults to default.", | 
| +                "nextPageToken": { | 
| +                    "description": "Continuation token for fetching the next page of results.", | 
| "type": "string" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "Instance": { | 
| -            "description": "An Instance resource is the computing unit that App Engine uses to automatically scale an application.", | 
| -            "id": "Instance", | 
| +        "ApiEndpointHandler": { | 
| +            "description": "Uses Google Cloud Endpoints to handle requests.", | 
| +            "id": "ApiEndpointHandler", | 
| "properties": { | 
| -                "vmDebugEnabled": { | 
| -                    "description": "Whether this instance is in debug mode. Only applicable for instances in App Engine flexible environment.@OutputOnly", | 
| -                    "type": "boolean" | 
| -                }, | 
| -                "requests": { | 
| -                    "description": "Number of requests since this instance was started.@OutputOnly", | 
| -                    "format": "int32", | 
| -                    "type": "integer" | 
| -                }, | 
| -                "appEngineRelease": { | 
| -                    "description": "App Engine release this instance is running on.@OutputOnly", | 
| -                    "type": "string" | 
| -                }, | 
| -                "vmName": { | 
| -                    "description": "Name of the virtual machine where this instance lives. Only applicable for instances in App Engine flexible environment.@OutputOnly", | 
| -                    "type": "string" | 
| -                }, | 
| -                "qps": { | 
| -                    "description": "Average queries per second (QPS) over the last minute.@OutputOnly", | 
| -                    "format": "float", | 
| -                    "type": "number" | 
| -                }, | 
| -                "vmId": { | 
| -                    "description": "Virtual machine ID of this instance. Only applicable for instances in App Engine flexible environment.@OutputOnly", | 
| -                    "type": "string" | 
| -                }, | 
| -                "vmZoneName": { | 
| -                    "description": "Zone where the virtual machine is located. Only applicable for instances in App Engine flexible environment.@OutputOnly", | 
| +                "scriptPath": { | 
| +                    "description": "Path to the script from the application root directory.", | 
| "type": "string" | 
| -                }, | 
| -                "name": { | 
| -                    "description": "Full path to the Instance resource in the API. Example: apps/myapp/services/default/versions/v1/instances/instance-1.@OutputOnly", | 
| +                } | 
| +            }, | 
| +            "type": "object" | 
| +        }, | 
| +        "ZipInfo": { | 
| +            "description": "The zip file information for a zip deployment.", | 
| +            "id": "ZipInfo", | 
| +            "properties": { | 
| +                "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/<bucket>/<object>'.", | 
| "type": "string" | 
| }, | 
| -                "averageLatency": { | 
| -                    "description": "Average latency (ms) over the last minute.@OutputOnly", | 
| +                "filesCount": { | 
| +                    "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.", | 
| "format": "int32", | 
| "type": "integer" | 
| +                } | 
| +            }, | 
| +            "type": "object" | 
| +        }, | 
| +        "AutomaticScaling": { | 
| +            "description": "Automatic scaling is based on request rate, response latencies, and other application metrics.", | 
| +            "id": "AutomaticScaling", | 
| +            "properties": { | 
| +                "cpuUtilization": { | 
| +                    "$ref": "CpuUtilization", | 
| +                    "description": "Target scaling by CPU usage." | 
| }, | 
| -                "id": { | 
| -                    "description": "Relative name of the instance within the version. Example: instance-1.@OutputOnly", | 
| -                    "type": "string" | 
| -                }, | 
| -                "vmIp": { | 
| -                    "description": "The IP address of this instance. Only applicable for instances in App Engine flexible environment.@OutputOnly", | 
| -                    "type": "string" | 
| -                }, | 
| -                "memoryUsage": { | 
| -                    "description": "Total memory in use (bytes).@OutputOnly", | 
| -                    "format": "int64", | 
| -                    "type": "string" | 
| -                }, | 
| -                "availability": { | 
| -                    "description": "Availability of the instance.@OutputOnly", | 
| -                    "enum": [ | 
| -                        "UNSPECIFIED", | 
| -                        "RESIDENT", | 
| -                        "DYNAMIC" | 
| -                    ], | 
| -                    "enumDescriptions": [ | 
| -                        "", | 
| -                        "", | 
| -                        "" | 
| -                    ], | 
| -                    "type": "string" | 
| +                "diskUtilization": { | 
| +                    "$ref": "DiskUtilization", | 
| +                    "description": "Target scaling by disk usage." | 
| }, | 
| -                "vmStatus": { | 
| -                    "description": "Status of the virtual machine where this instance lives. Only applicable for instances in App Engine flexible environment.@OutputOnly", | 
| +                "minPendingLatency": { | 
| +                    "description": "Minimum amount of time a request should wait in the pending queue before starting a new instance to handle it.", | 
| +                    "format": "google-duration", | 
| "type": "string" | 
| }, | 
| -                "errors": { | 
| -                    "description": "Number of errors since this instance was started.@OutputOnly", | 
| +                "maxIdleInstances": { | 
| +                    "description": "Maximum number of idle instances that should be maintained for this version.", | 
| "format": "int32", | 
| "type": "integer" | 
| }, | 
| -                "startTime": { | 
| -                    "description": "Time that this instance was started.@OutputOnly", | 
| -                    "format": "google-datetime", | 
| -                    "type": "string" | 
| -                } | 
| -            }, | 
| -            "type": "object" | 
| -        }, | 
| -        "LivenessCheck": { | 
| -            "description": "Health checking configuration for VM instances. Unhealthy instances are killed and replaced with new instances.", | 
| -            "id": "LivenessCheck", | 
| -            "properties": { | 
| -                "checkInterval": { | 
| -                    "description": "Interval between health checks.", | 
| -                    "format": "google-duration", | 
| -                    "type": "string" | 
| +                "requestUtilization": { | 
| +                    "$ref": "RequestUtilization", | 
| +                    "description": "Target scaling by request utilization." | 
| }, | 
| -                "failureThreshold": { | 
| -                    "description": "Number of consecutive failed checks required before considering the VM unhealthy.", | 
| -                    "format": "uint32", | 
| +                "minIdleInstances": { | 
| +                    "description": "Minimum number of idle instances that should be maintained for this version. Only applicable for the default version of a service.", | 
| +                    "format": "int32", | 
| "type": "integer" | 
| }, | 
| -                "timeout": { | 
| -                    "description": "Time before the check is considered failed.", | 
| -                    "format": "google-duration", | 
| -                    "type": "string" | 
| +                "maxTotalInstances": { | 
| +                    "description": "Maximum number of instances that should be started to handle requests.", | 
| +                    "format": "int32", | 
| +                    "type": "integer" | 
| }, | 
| -                "initialDelay": { | 
| -                    "description": "The initial delay before starting to execute the checks.", | 
| -                    "format": "google-duration", | 
| -                    "type": "string" | 
| +                "minTotalInstances": { | 
| +                    "description": "Minimum number of instances that should be maintained for this version.", | 
| +                    "format": "int32", | 
| +                    "type": "integer" | 
| }, | 
| -                "path": { | 
| -                    "description": "The request path.", | 
| -                    "type": "string" | 
| +                "networkUtilization": { | 
| +                    "$ref": "NetworkUtilization", | 
| +                    "description": "Target scaling by network usage." | 
| }, | 
| -                "successThreshold": { | 
| -                    "description": "Number of consecutive successful checks required before considering the VM healthy.", | 
| -                    "format": "uint32", | 
| +                "maxConcurrentRequests": { | 
| +                    "description": "Number of concurrent requests an automatic scaling instance can accept before the scheduler spawns a new instance.Defaults to a runtime-specific value.", | 
| +                    "format": "int32", | 
| "type": "integer" | 
| }, | 
| -                "host": { | 
| -                    "description": "Host header to send when performing a HTTP Liveness check. Example: \"myapp.appspot.com\"", | 
| +                "coolDownPeriod": { | 
| +                    "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.", | 
| +                    "format": "google-duration", | 
| +                    "type": "string" | 
| +                }, | 
| +                "maxPendingLatency": { | 
| +                    "description": "Maximum amount of time that a request should wait in the pending queue before starting a new instance to handle it.", | 
| +                    "format": "google-duration", | 
| "type": "string" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "Location": { | 
| -            "description": "A resource that represents Google Cloud Platform location.", | 
| -            "id": "Location", | 
| +        "Library": { | 
| +            "description": "Third-party Python runtime library that is required by the application.", | 
| +            "id": "Library", | 
| "properties": { | 
| -                "labels": { | 
| -                    "additionalProperties": { | 
| -                        "type": "string" | 
| -                    }, | 
| -                    "description": "Cross-service attributes for the location. For example\n{\"cloud.googleapis.com/region\": \"us-east1\"}\n", | 
| -                    "type": "object" | 
| -                }, | 
| "name": { | 
| -                    "description": "Resource name for the location, which may vary between implementations. For example: \"projects/example-project/locations/us-east1\"", | 
| +                    "description": "Name of the library. Example: \"django\".", | 
| "type": "string" | 
| }, | 
| -                "locationId": { | 
| -                    "description": "The canonical id for this location. For example: \"us-east1\".", | 
| +                "version": { | 
| +                    "description": "Version of the library to select, or \"latest\".", | 
| +                    "type": "string" | 
| +                } | 
| +            }, | 
| +            "type": "object" | 
| +        }, | 
| +        "ListLocationsResponse": { | 
| +            "description": "The response message for Locations.ListLocations.", | 
| +            "id": "ListLocationsResponse", | 
| +            "properties": { | 
| +                "nextPageToken": { | 
| +                    "description": "The standard List next-page token.", | 
| "type": "string" | 
| }, | 
| -                "metadata": { | 
| -                    "additionalProperties": { | 
| -                        "description": "Properties of the object. Contains field @type with type URL.", | 
| -                        "type": "any" | 
| +                "locations": { | 
| +                    "description": "A list of locations that matches the specified filter in the request.", | 
| +                    "items": { | 
| +                        "$ref": "Location" | 
| }, | 
| -                    "description": "Service-specific metadata. For example the available capacity at the given location.", | 
| -                    "type": "object" | 
| +                    "type": "array" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "NetworkUtilization": { | 
| -            "description": "Target scaling by network usage. Only applicable for VM runtimes.", | 
| -            "id": "NetworkUtilization", | 
| +        "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.", | 
| +            "id": "ContainerInfo", | 
| "properties": { | 
| -                "targetReceivedPacketsPerSecond": { | 
| -                    "description": "Target packets received per second.", | 
| -                    "format": "int32", | 
| -                    "type": "integer" | 
| -                }, | 
| -                "targetSentBytesPerSecond": { | 
| -                    "description": "Target bytes sent per second.", | 
| -                    "format": "int32", | 
| -                    "type": "integer" | 
| -                }, | 
| -                "targetReceivedBytesPerSecond": { | 
| -                    "description": "Target bytes received per second.", | 
| +                "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\"", | 
| +                    "type": "string" | 
| +                } | 
| +            }, | 
| +            "type": "object" | 
| +        }, | 
| +        "RequestUtilization": { | 
| +            "description": "Target scaling by request utilization. Only applicable for VM runtimes.", | 
| +            "id": "RequestUtilization", | 
| +            "properties": { | 
| +                "targetRequestCountPerSecond": { | 
| +                    "description": "Target requests per second.", | 
| "format": "int32", | 
| "type": "integer" | 
| }, | 
| -                "targetSentPacketsPerSecond": { | 
| -                    "description": "Target packets sent per second.", | 
| +                "targetConcurrentRequests": { | 
| +                    "description": "Target number of concurrent requests.", | 
| "format": "int32", | 
| "type": "integer" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "HealthCheck": { | 
| -            "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.", | 
| -            "id": "HealthCheck", | 
| +        "EndpointsApiService": { | 
| +            "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).", | 
| +            "id": "EndpointsApiService", | 
| "properties": { | 
| -                "timeout": { | 
| -                    "description": "Time before the health check is considered failed.", | 
| -                    "format": "google-duration", | 
| -                    "type": "string" | 
| -                }, | 
| -                "unhealthyThreshold": { | 
| -                    "description": "Number of consecutive failed health checks required before removing traffic.", | 
| -                    "format": "uint32", | 
| -                    "type": "integer" | 
| -                }, | 
| -                "disableHealthCheck": { | 
| -                    "description": "Whether to explicitly disable health checks for this instance.", | 
| -                    "type": "boolean" | 
| -                }, | 
| -                "host": { | 
| -                    "description": "Host header to send when performing an HTTP health check. Example: \"myapp.appspot.com\"", | 
| +                "configId": { | 
| +                    "description": "Endpoints service configuration id as specified by the Service Management API. For example \"2016-09-19r1\"", | 
| "type": "string" | 
| }, | 
| -                "healthyThreshold": { | 
| -                    "description": "Number of consecutive successful health checks required before receiving traffic.", | 
| -                    "format": "uint32", | 
| -                    "type": "integer" | 
| -                }, | 
| -                "restartThreshold": { | 
| -                    "description": "Number of consecutive failed health checks required before an instance is restarted.", | 
| -                    "format": "uint32", | 
| -                    "type": "integer" | 
| -                }, | 
| -                "checkInterval": { | 
| -                    "description": "Interval between health checks.", | 
| -                    "format": "google-duration", | 
| +                "name": { | 
| +                    "description": "Endpoints service name which is the name of the \"service\" resource in the Service Management API. For example \"myapi.endpoints.myproject.cloud.goog\"", | 
| "type": "string" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "ReadinessCheck": { | 
| -            "description": "Readiness checking configuration for VM instances. Unhealthy instances are removed from traffic rotation.", | 
| -            "id": "ReadinessCheck", | 
| +        "UrlMap": { | 
| +            "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.", | 
| +            "id": "UrlMap", | 
| "properties": { | 
| -                "checkInterval": { | 
| -                    "description": "Interval between health checks.", | 
| -                    "format": "google-duration", | 
| +                "securityLevel": { | 
| +                    "description": "Security (HTTPS) enforcement for this URL.", | 
| +                    "enum": [ | 
| +                        "SECURE_UNSPECIFIED", | 
| +                        "SECURE_DEFAULT", | 
| +                        "SECURE_NEVER", | 
| +                        "SECURE_OPTIONAL", | 
| +                        "SECURE_ALWAYS" | 
| +                    ], | 
| +                    "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." | 
| +                    ], | 
| "type": "string" | 
| }, | 
| -                "timeout": { | 
| -                    "description": "Time before the check is considered failed.", | 
| -                    "format": "google-duration", | 
| +                "authFailAction": { | 
| +                    "description": "Action to take when users access resources that require authentication. Defaults to redirect.", | 
| +                    "enum": [ | 
| +                        "AUTH_FAIL_ACTION_UNSPECIFIED", | 
| +                        "AUTH_FAIL_ACTION_REDIRECT", | 
| +                        "AUTH_FAIL_ACTION_UNAUTHORIZED" | 
| +                    ], | 
| +                    "enumDescriptions": [ | 
| +                        "Not specified. AUTH_FAIL_ACTION_REDIRECT is assumed.", | 
| +                        "Redirects user to \"accounts.google.com\". The user is redirected back to the application URL after signing in or creating an account.", | 
| +                        "Rejects request with a 401 HTTP status code and an error message." | 
| +                    ], | 
| "type": "string" | 
| }, | 
| -                "failureThreshold": { | 
| -                    "description": "Number of consecutive failed checks required before removing traffic.", | 
| -                    "format": "uint32", | 
| -                    "type": "integer" | 
| +                "script": { | 
| +                    "$ref": "ScriptHandler", | 
| +                    "description": "Executes a script to handle the request that matches this URL pattern." | 
| }, | 
| -                "appStartTimeout": { | 
| -                    "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.", | 
| -                    "format": "google-duration", | 
| +                "urlRegex": { | 
| +                    "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.", | 
| "type": "string" | 
| }, | 
| -                "path": { | 
| -                    "description": "The request path.", | 
| +                "login": { | 
| +                    "description": "Level of login required to access this resource.", | 
| +                    "enum": [ | 
| +                        "LOGIN_UNSPECIFIED", | 
| +                        "LOGIN_OPTIONAL", | 
| +                        "LOGIN_ADMIN", | 
| +                        "LOGIN_REQUIRED" | 
| +                    ], | 
| +                    "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." | 
| +                    ], | 
| "type": "string" | 
| }, | 
| -                "host": { | 
| -                    "description": "Host header to send when performing a HTTP Readiness check. Example: \"myapp.appspot.com\"", | 
| -                    "type": "string" | 
| +                "apiEndpoint": { | 
| +                    "$ref": "ApiEndpointHandler", | 
| +                    "description": "Uses API Endpoints to handle requests." | 
| }, | 
| -                "successThreshold": { | 
| -                    "description": "Number of consecutive successful checks required before receiving traffic.", | 
| -                    "format": "uint32", | 
| -                    "type": "integer" | 
| -                } | 
| -            }, | 
| -            "type": "object" | 
| -        }, | 
| -        "DebugInstanceRequest": { | 
| -            "description": "Request message for Instances.DebugInstance.", | 
| -            "id": "DebugInstanceRequest", | 
| -            "properties": { | 
| -                "sshKey": { | 
| -                    "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).", | 
| +                "staticFiles": { | 
| +                    "$ref": "StaticFilesHandler", | 
| +                    "description": "Returns the contents of a file, such as an image, as the response." | 
| +                }, | 
| +                "redirectHttpResponseCode": { | 
| +                    "description": "30x code to use when performing redirects for the secure field. Defaults to 302.", | 
| +                    "enum": [ | 
| +                        "REDIRECT_HTTP_RESPONSE_CODE_UNSPECIFIED", | 
| +                        "REDIRECT_HTTP_RESPONSE_CODE_301", | 
| +                        "REDIRECT_HTTP_RESPONSE_CODE_302", | 
| +                        "REDIRECT_HTTP_RESPONSE_CODE_303", | 
| +                        "REDIRECT_HTTP_RESPONSE_CODE_307" | 
| +                    ], | 
| +                    "enumDescriptions": [ | 
| +                        "Not specified. 302 is assumed.", | 
| +                        "301 Moved Permanently code.", | 
| +                        "302 Moved Temporarily code.", | 
| +                        "303 See Other code.", | 
| +                        "307 Temporary Redirect code." | 
| +                    ], | 
| "type": "string" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "OperationMetadataV1Beta5": { | 
| -            "description": "Metadata for the given google.longrunning.Operation.", | 
| -            "id": "OperationMetadataV1Beta5", | 
| +        "ApiConfigHandler": { | 
| +            "description": "Google Cloud Endpoints (https://cloud.google.com/appengine/docs/python/endpoints/) configuration for API handlers.", | 
| +            "id": "ApiConfigHandler", | 
| "properties": { | 
| -                "method": { | 
| -                    "description": "API method name that initiated this operation. Example: google.appengine.v1beta5.Version.CreateVersion.@OutputOnly", | 
| +                "securityLevel": { | 
| +                    "description": "Security (HTTPS) enforcement for this URL.", | 
| +                    "enum": [ | 
| +                        "SECURE_UNSPECIFIED", | 
| +                        "SECURE_DEFAULT", | 
| +                        "SECURE_NEVER", | 
| +                        "SECURE_OPTIONAL", | 
| +                        "SECURE_ALWAYS" | 
| +                    ], | 
| +                    "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." | 
| +                    ], | 
| "type": "string" | 
| }, | 
| -                "insertTime": { | 
| -                    "description": "Timestamp that this operation was created.@OutputOnly", | 
| -                    "format": "google-datetime", | 
| +                "authFailAction": { | 
| +                    "description": "Action to take when users access resources that require authentication. Defaults to redirect.", | 
| +                    "enum": [ | 
| +                        "AUTH_FAIL_ACTION_UNSPECIFIED", | 
| +                        "AUTH_FAIL_ACTION_REDIRECT", | 
| +                        "AUTH_FAIL_ACTION_UNAUTHORIZED" | 
| +                    ], | 
| +                    "enumDescriptions": [ | 
| +                        "Not specified. AUTH_FAIL_ACTION_REDIRECT is assumed.", | 
| +                        "Redirects user to \"accounts.google.com\". The user is redirected back to the application URL after signing in or creating an account.", | 
| +                        "Rejects request with a 401 HTTP status code and an error message." | 
| +                    ], | 
| "type": "string" | 
| }, | 
| -                "endTime": { | 
| -                    "description": "Timestamp that this operation completed.@OutputOnly", | 
| -                    "format": "google-datetime", | 
| +                "script": { | 
| +                    "description": "Path to the script from the application root directory.", | 
| "type": "string" | 
| }, | 
| -                "target": { | 
| -                    "description": "Name of the resource that this operation is acting on. Example: apps/myapp/services/default.@OutputOnly", | 
| +                "login": { | 
| +                    "description": "Level of login required to access this resource. Defaults to optional.", | 
| +                    "enum": [ | 
| +                        "LOGIN_UNSPECIFIED", | 
| +                        "LOGIN_OPTIONAL", | 
| +                        "LOGIN_ADMIN", | 
| +                        "LOGIN_REQUIRED" | 
| +                    ], | 
| +                    "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." | 
| +                    ], | 
| "type": "string" | 
| }, | 
| -                "user": { | 
| -                    "description": "User who requested this operation.@OutputOnly", | 
| +                "url": { | 
| +                    "description": "URL to serve the endpoint at.", | 
| "type": "string" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "Version": { | 
| -            "description": "A Version resource is a specific set of source code and configuration files that are deployed into a service.", | 
| -            "id": "Version", | 
| +        "Operation": { | 
| +            "description": "This resource represents a long-running operation that is the result of a network API call.", | 
| +            "id": "Operation", | 
| "properties": { | 
| -                "basicScaling": { | 
| -                    "$ref": "BasicScaling", | 
| -                    "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." | 
| -                }, | 
| -                "runtime": { | 
| -                    "description": "Desired runtime. Example: python27.", | 
| -                    "type": "string" | 
| -                }, | 
| -                "createdBy": { | 
| -                    "description": "Email address of the user who created this version.@OutputOnly", | 
| -                    "type": "string" | 
| -                }, | 
| -                "id": { | 
| -                    "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-\".", | 
| -                    "type": "string" | 
| -                }, | 
| -                "envVariables": { | 
| +                "response": { | 
| "additionalProperties": { | 
| -                        "type": "string" | 
| +                        "description": "Properties of the object. Contains field @type with type URL.", | 
| +                        "type": "any" | 
| }, | 
| -                    "description": "Environment variables available to the application.Only returned in GET requests if view=FULL is set.", | 
| +                    "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.", | 
| "type": "object" | 
| }, | 
| -                "livenessCheck": { | 
| -                    "$ref": "LivenessCheck", | 
| -                    "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." | 
| +                "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 have the format of operations/some/unique/name.", | 
| +                    "type": "string" | 
| }, | 
| -                "network": { | 
| -                    "$ref": "Network", | 
| -                    "description": "Extra network settings. Only applicable for VM runtimes." | 
| +                "error": { | 
| +                    "$ref": "Status", | 
| +                    "description": "The error result of the operation in case of failure or cancellation." | 
| }, | 
| -                "betaSettings": { | 
| +                "metadata": { | 
| "additionalProperties": { | 
| -                        "type": "string" | 
| +                        "description": "Properties of the object. Contains field @type with type URL.", | 
| +                        "type": "any" | 
| }, | 
| -                    "description": "Metadata settings that are supplied to this version to enable beta runtime features.", | 
| +                    "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" | 
| }, | 
| -                "env": { | 
| -                    "description": "App Engine execution environment for this version.Defaults to standard.", | 
| +                "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" | 
| +                } | 
| +            }, | 
| +            "type": "object" | 
| +        }, | 
| +        "StaticFilesHandler": { | 
| +            "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.", | 
| +            "id": "StaticFilesHandler", | 
| +            "properties": { | 
| +                "expiration": { | 
| +                    "description": "Time a static file served by this handler should be cached by web proxies and browsers.", | 
| +                    "format": "google-duration", | 
| "type": "string" | 
| }, | 
| -                "handlers": { | 
| -                    "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.", | 
| -                    "items": { | 
| -                        "$ref": "UrlMap" | 
| +                "httpHeaders": { | 
| +                    "additionalProperties": { | 
| +                        "type": "string" | 
| }, | 
| -                    "type": "array" | 
| -                }, | 
| -                "automaticScaling": { | 
| -                    "$ref": "AutomaticScaling", | 
| -                    "description": "Automatic scaling is based on request rate, response latencies, and other application metrics." | 
| -                }, | 
| -                "diskUsageBytes": { | 
| -                    "description": "Total size in bytes of all the files that are included in this version and curerntly hosted on the App Engine disk.@OutputOnly", | 
| -                    "format": "int64", | 
| -                    "type": "string" | 
| -                }, | 
| -                "healthCheck": { | 
| -                    "$ref": "HealthCheck", | 
| -                    "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": "HTTP headers to use for all responses from these URLs.", | 
| +                    "type": "object" | 
| }, | 
| -                "threadsafe": { | 
| -                    "description": "Whether multiple requests can be dispatched to this version at once.", | 
| +                "applicationReadable": { | 
| +                    "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" | 
| }, | 
| -                "readinessCheck": { | 
| -                    "$ref": "ReadinessCheck", | 
| -                    "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." | 
| -                }, | 
| -                "manualScaling": { | 
| -                    "$ref": "ManualScaling", | 
| -                    "description": "A service with manual scaling runs continuously, allowing you to perform complex initialization and rely on the state of its memory over time." | 
| -                }, | 
| -                "name": { | 
| -                    "description": "Full path to the Version resource in the API. Example: apps/myapp/services/default/versions/v1.@OutputOnly", | 
| +                "uploadPathRegex": { | 
| +                    "description": "Regular expression that matches the file paths for all files that should be referenced by this handler.", | 
| "type": "string" | 
| }, | 
| -                "apiConfig": { | 
| -                    "$ref": "ApiConfigHandler", | 
| -                    "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." | 
| -                }, | 
| -                "endpointsApiService": { | 
| -                    "$ref": "EndpointsApiService", | 
| -                    "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." | 
| -                }, | 
| -                "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", | 
| +                "path": { | 
| +                    "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.", | 
| "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.", | 
| +                "mimeType": { | 
| +                    "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.", | 
| "type": "string" | 
| }, | 
| -                "servingStatus": { | 
| -                    "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.", | 
| -                    "enum": [ | 
| -                        "SERVING_STATUS_UNSPECIFIED", | 
| -                        "SERVING", | 
| -                        "STOPPED" | 
| -                    ], | 
| -                    "enumDescriptions": [ | 
| -                        "Not specified.", | 
| -                        "Currently serving. Instances are created according to the scaling settings of the version.", | 
| -                        "Disabled. No instances will be created and the scaling settings are ignored until the state of the version changes to SERVING." | 
| -                    ], | 
| +                "requireMatchingFile": { | 
| +                    "description": "Whether this handler should match the request if the file referenced by the handler does not exist.", | 
| +                    "type": "boolean" | 
| +                } | 
| +            }, | 
| +            "type": "object" | 
| +        }, | 
| +        "BasicScaling": { | 
| +            "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.", | 
| +            "id": "BasicScaling", | 
| +            "properties": { | 
| +                "maxInstances": { | 
| +                    "description": "Maximum number of instances to create for this version.", | 
| +                    "format": "int32", | 
| +                    "type": "integer" | 
| +                }, | 
| +                "idleTimeout": { | 
| +                    "description": "Duration of time after the last request that an instance must wait before the instance is shut down.", | 
| +                    "format": "google-duration", | 
| "type": "string" | 
| +                } | 
| +            }, | 
| +            "type": "object" | 
| +        }, | 
| +        "DiskUtilization": { | 
| +            "description": "Target scaling by disk usage. Only applicable for VM runtimes.", | 
| +            "id": "DiskUtilization", | 
| +            "properties": { | 
| +                "targetReadOpsPerSecond": { | 
| +                    "description": "Target ops read per seconds.", | 
| +                    "format": "int32", | 
| +                    "type": "integer" | 
| }, | 
| -                "deployment": { | 
| -                    "$ref": "Deployment", | 
| -                    "description": "Code and application artifacts that make up this version.Only returned in GET requests if view=FULL is set." | 
| +                "targetReadBytesPerSecond": { | 
| +                    "description": "Target bytes read per second.", | 
| +                    "format": "int32", | 
| +                    "type": "integer" | 
| }, | 
| -                "runtimeApiVersion": { | 
| -                    "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/<language>/config/appref", | 
| -                    "type": "string" | 
| +                "targetWriteOpsPerSecond": { | 
| +                    "description": "Target ops written per second.", | 
| +                    "format": "int32", | 
| +                    "type": "integer" | 
| }, | 
| -                "createTime": { | 
| -                    "description": "Time that this version was created.@OutputOnly", | 
| -                    "format": "google-datetime", | 
| +                "targetWriteBytesPerSecond": { | 
| +                    "description": "Target bytes written per second.", | 
| +                    "format": "int32", | 
| +                    "type": "integer" | 
| +                } | 
| +            }, | 
| +            "type": "object" | 
| +        }, | 
| +        "CpuUtilization": { | 
| +            "description": "Target scaling by CPU usage.", | 
| +            "id": "CpuUtilization", | 
| +            "properties": { | 
| +                "aggregationWindowLength": { | 
| +                    "description": "Period of time over which CPU utilization is calculated.", | 
| +                    "format": "google-duration", | 
| "type": "string" | 
| }, | 
| -                "resources": { | 
| -                    "$ref": "Resources", | 
| -                    "description": "Machine resources for this version. Only applicable for VM runtimes." | 
| -                }, | 
| -                "inboundServices": { | 
| -                    "description": "Before an application can receive email or XMPP messages, the application must be configured to enable the service.", | 
| -                    "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." | 
| -                    ], | 
| +                "targetUtilization": { | 
| +                    "description": "Target CPU utilization ratio to maintain when scaling. Must be between 0 and 1.", | 
| +                    "format": "double", | 
| +                    "type": "number" | 
| +                } | 
| +            }, | 
| +            "type": "object" | 
| +        }, | 
| +        "Status": { | 
| +            "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.", | 
| +            "id": "Status", | 
| +            "properties": { | 
| +                "details": { | 
| +                    "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use.", | 
| "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" | 
| +                        "additionalProperties": { | 
| +                            "description": "Properties of the object. Contains field @type with type URL.", | 
| +                            "type": "any" | 
| +                        }, | 
| +                        "type": "object" | 
| }, | 
| "type": "array" | 
| }, | 
| -                "errorHandlers": { | 
| -                    "description": "Custom static error pages. Limited to 10KB per page.Only returned in GET requests if view=FULL is set.", | 
| -                    "items": { | 
| -                        "$ref": "ErrorHandler" | 
| -                    }, | 
| -                    "type": "array" | 
| +                "code": { | 
| +                    "description": "The status code, which should be an enum value of google.rpc.Code.", | 
| +                    "format": "int32", | 
| +                    "type": "integer" | 
| }, | 
| -                "defaultExpiration": { | 
| -                    "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/v1/apps.services.versions#staticfileshandler) does not specify its own expiration time.Only returned in GET requests if view=FULL is set.", | 
| -                    "format": "google-duration", | 
| +                "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" | 
| +                } | 
| +            }, | 
| +            "type": "object" | 
| +        }, | 
| +        "IdentityAwareProxy": { | 
| +            "description": "Identity-Aware Proxy", | 
| +            "id": "IdentityAwareProxy", | 
| +            "properties": { | 
| +                "oauth2ClientSecret": { | 
| +                    "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", | 
| "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" | 
| +                "oauth2ClientId": { | 
| +                    "description": "OAuth2 client ID to use for the authentication flow.", | 
| +                    "type": "string" | 
| }, | 
| -                "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.", | 
| +                "oauth2ClientSecretSha256": { | 
| +                    "description": "Hex-encoded SHA-256 hash of the client secret.@OutputOnly", | 
| "type": "string" | 
| +                }, | 
| +                "enabled": { | 
| +                    "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.", | 
| +                    "type": "boolean" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "RepairApplicationRequest": { | 
| -            "description": "Request message for 'Applications.RepairApplication'.", | 
| -            "id": "RepairApplicationRequest", | 
| -            "properties": {}, | 
| +        "ManualScaling": { | 
| +            "description": "A service with manual scaling runs continuously, allowing you to perform complex initialization and rely on the state of its memory over time.", | 
| +            "id": "ManualScaling", | 
| +            "properties": { | 
| +                "instances": { | 
| +                    "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.", | 
| +                    "format": "int32", | 
| +                    "type": "integer" | 
| +                } | 
| +            }, | 
| "type": "object" | 
| }, | 
| -        "ScriptHandler": { | 
| -            "description": "Executes a script to handle the request that matches the URL pattern.", | 
| -            "id": "ScriptHandler", | 
| +        "LocationMetadata": { | 
| +            "description": "Metadata for the given google.cloud.location.Location.", | 
| +            "id": "LocationMetadata", | 
| "properties": { | 
| -                "scriptPath": { | 
| -                    "description": "Path to the script from the application root directory.", | 
| -                    "type": "string" | 
| +                "standardEnvironmentAvailable": { | 
| +                    "description": "App Engine Standard Environment is available in the given location.@OutputOnly", | 
| +                    "type": "boolean" | 
| +                }, | 
| +                "flexibleEnvironmentAvailable": { | 
| +                    "description": "App Engine Flexible Environment is available in the given location.@OutputOnly", | 
| +                    "type": "boolean" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "FileInfo": { | 
| -            "description": "Single source file that is part of the version to be deployed. Each source file that is deployed must be specified separately.", | 
| -            "id": "FileInfo", | 
| +        "Service": { | 
| +            "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.", | 
| +            "id": "Service", | 
| "properties": { | 
| -                "mimeType": { | 
| -                    "description": "The MIME type of the file.Defaults to the value from Google Cloud Storage.", | 
| +                "id": { | 
| +                    "description": "Relative name of the service within the application. Example: default.@OutputOnly", | 
| "type": "string" | 
| }, | 
| -                "sourceUrl": { | 
| -                    "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/<bucket>/<object>'.", | 
| +                "name": { | 
| +                    "description": "Full path to the Service resource in the API. Example: apps/myapp/services/default.@OutputOnly", | 
| "type": "string" | 
| }, | 
| -                "sha1Sum": { | 
| -                    "description": "The SHA1 hash of the file, in hex.", | 
| +                "split": { | 
| +                    "$ref": "TrafficSplit", | 
| +                    "description": "Mapping that defines fractional HTTP traffic diversion to different versions within the service." | 
| +                } | 
| +            }, | 
| +            "type": "object" | 
| +        }, | 
| +        "ListOperationsResponse": { | 
| +            "description": "The response message for Operations.ListOperations.", | 
| +            "id": "ListOperationsResponse", | 
| +            "properties": { | 
| +                "nextPageToken": { | 
| +                    "description": "The standard List next-page token.", | 
| "type": "string" | 
| +                }, | 
| +                "operations": { | 
| +                    "description": "A list of operations that matches the specified filter in the request.", | 
| +                    "items": { | 
| +                        "$ref": "Operation" | 
| +                    }, | 
| +                    "type": "array" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "OperationMetadataExperimental": { | 
| +        "OperationMetadata": { | 
| "description": "Metadata for the given google.longrunning.Operation.", | 
| -            "id": "OperationMetadataExperimental", | 
| +            "id": "OperationMetadata", | 
| "properties": { | 
| -                "method": { | 
| -                    "description": "API method that initiated this operation. Example: google.appengine.experimental.CustomDomains.CreateCustomDomain.@OutputOnly", | 
| +                "endTime": { | 
| +                    "description": "Timestamp that this operation completed.@OutputOnly", | 
| +                    "format": "google-datetime", | 
| +                    "type": "string" | 
| +                }, | 
| +                "operationType": { | 
| +                    "description": "Type of this operation. Deprecated, use method field instead. Example: \"create_version\".@OutputOnly", | 
| "type": "string" | 
| }, | 
| "insertTime": { | 
| -                    "description": "Time that this operation was created.@OutputOnly", | 
| +                    "description": "Timestamp that this operation was created.@OutputOnly", | 
| "format": "google-datetime", | 
| "type": "string" | 
| }, | 
| -                "endTime": { | 
| -                    "description": "Time that this operation completed.@OutputOnly", | 
| -                    "format": "google-datetime", | 
| +                "user": { | 
| +                    "description": "User who requested this operation.@OutputOnly", | 
| "type": "string" | 
| }, | 
| "target": { | 
| -                    "description": "Name of the resource that this operation is acting on. Example: apps/myapp/customDomains/example.com.@OutputOnly", | 
| +                    "description": "Name of the resource that this operation is acting on. Example: apps/myapp/modules/default.@OutputOnly", | 
| "type": "string" | 
| }, | 
| -                "user": { | 
| -                    "description": "User who requested this operation.@OutputOnly", | 
| +                "method": { | 
| +                    "description": "API method that initiated this operation. Example: google.appengine.v1beta4.Version.CreateVersion.@OutputOnly", | 
| "type": "string" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "TrafficSplit": { | 
| -            "description": "Traffic routing configuration for versions within a single service. Traffic splits define how traffic directed to the service is assigned to versions.", | 
| -            "id": "TrafficSplit", | 
| +        "ErrorHandler": { | 
| +            "description": "Custom static error page to be served when an error occurs.", | 
| +            "id": "ErrorHandler", | 
| "properties": { | 
| -                "allocations": { | 
| -                    "additionalProperties": { | 
| -                        "format": "double", | 
| -                        "type": "number" | 
| -                    }, | 
| -                    "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" | 
| +                "mimeType": { | 
| +                    "description": "MIME type of file. Defaults to text/html.", | 
| +                    "type": "string" | 
| }, | 
| -                "shardBy": { | 
| -                    "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.", | 
| +                "errorCode": { | 
| +                    "description": "Error condition this handler applies to.", | 
| "enum": [ | 
| -                        "UNSPECIFIED", | 
| -                        "COOKIE", | 
| -                        "IP", | 
| -                        "RANDOM" | 
| +                        "ERROR_CODE_UNSPECIFIED", | 
| +                        "ERROR_CODE_DEFAULT", | 
| +                        "ERROR_CODE_OVER_QUOTA", | 
| +                        "ERROR_CODE_DOS_API_DENIAL", | 
| +                        "ERROR_CODE_TIMEOUT" | 
| ], | 
| -                    "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." | 
| +                    "enumDescriptions": [ | 
| +                        "Not specified. ERROR_CODE_DEFAULT is assumed.", | 
| +                        "All other error types.", | 
| +                        "Application has exceeded a resource quota.", | 
| +                        "Client blocked by the application's Denial of Service protection configuration.", | 
| +                        "Deadline reached before the application responds." | 
| ], | 
| "type": "string" | 
| +                }, | 
| +                "staticFile": { | 
| +                    "description": "Static file content to be served for this error.", | 
| +                    "type": "string" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "OperationMetadataV1Beta": { | 
| +        "OperationMetadataV1": { | 
| "description": "Metadata for the given google.longrunning.Operation.", | 
| -            "id": "OperationMetadataV1Beta", | 
| +            "id": "OperationMetadataV1", | 
| "properties": { | 
| -                "method": { | 
| -                    "description": "API method that initiated this operation. Example: google.appengine.v1beta.Versions.CreateVersion.@OutputOnly", | 
| -                    "type": "string" | 
| -                }, | 
| "endTime": { | 
| "description": "Time that this operation completed.@OutputOnly", | 
| "format": "google-datetime", | 
| @@ -2175,352 +2146,381 @@ | 
| "format": "google-datetime", | 
| "type": "string" | 
| }, | 
| -                "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" | 
| }, | 
| +                "target": { | 
| +                    "description": "Name of the resource that this operation is acting on. Example: apps/myapp/services/default.@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.v1.Versions.CreateVersion.@OutputOnly", | 
| +                    "type": "string" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "ListServicesResponse": { | 
| -            "description": "Response message for Services.ListServices.", | 
| -            "id": "ListServicesResponse", | 
| +        "Network": { | 
| +            "description": "Extra network settings. Only applicable for App Engine flexible environment versions", | 
| +            "id": "Network", | 
| "properties": { | 
| -                "nextPageToken": { | 
| -                    "description": "Continuation token for fetching the next page of results.", | 
| +                "subnetworkName": { | 
| +                    "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.", | 
| "type": "string" | 
| }, | 
| -                "services": { | 
| -                    "description": "The services belonging to the requested application.", | 
| +                "instanceTag": { | 
| +                    "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": { | 
| -                        "$ref": "Service" | 
| +                        "type": "string" | 
| }, | 
| "type": "array" | 
| -                } | 
| -            }, | 
| -            "type": "object" | 
| -        }, | 
| -        "Deployment": { | 
| -            "description": "Code and application artifacts used to deploy a version to App Engine.", | 
| -            "id": "Deployment", | 
| -            "properties": { | 
| -                "zip": { | 
| -                    "$ref": "ZipInfo", | 
| -                    "description": "The zip file for this deployment, if this is a zip deployment." | 
| -                }, | 
| -                "container": { | 
| -                    "$ref": "ContainerInfo", | 
| -                    "description": "The Docker image for the container that runs the version. Only applicable for instances running in the App Engine flexible environment." | 
| }, | 
| -                "files": { | 
| -                    "additionalProperties": { | 
| -                        "$ref": "FileInfo" | 
| -                    }, | 
| -                    "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.", | 
| -                    "type": "object" | 
| +                "name": { | 
| +                    "description": "Google Compute Engine network where the virtual machines are created. Specify the short name, not the resource path.Defaults to default.", | 
| +                    "type": "string" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "Resources": { | 
| -            "description": "Machine resources for a version.", | 
| -            "id": "Resources", | 
| +        "Application": { | 
| +            "description": "An Application resource contains the top-level configuration of an App Engine application. Next tag: 20", | 
| +            "id": "Application", | 
| "properties": { | 
| -                "volumes": { | 
| -                    "description": "User specified volumes.", | 
| -                    "items": { | 
| -                        "$ref": "Volume" | 
| -                    }, | 
| -                    "type": "array" | 
| +                "servingStatus": { | 
| +                    "description": "Serving status of this application.", | 
| +                    "enum": [ | 
| +                        "UNSPECIFIED", | 
| +                        "SERVING", | 
| +                        "USER_DISABLED", | 
| +                        "SYSTEM_DISABLED" | 
| +                    ], | 
| +                    "enumDescriptions": [ | 
| +                        "Serving status is unspecified.", | 
| +                        "Application is serving.", | 
| +                        "Application has been disabled by the user.", | 
| +                        "Application has been disabled by the system." | 
| +                    ], | 
| +                    "type": "string" | 
| }, | 
| -                "diskGb": { | 
| -                    "description": "Disk size (GB) needed.", | 
| -                    "format": "double", | 
| -                    "type": "number" | 
| +                "defaultHostname": { | 
| +                    "description": "Hostname used to reach this application, as resolved by App Engine.@OutputOnly", | 
| +                    "type": "string" | 
| }, | 
| -                "memoryGb": { | 
| -                    "description": "Memory (GB) needed.", | 
| -                    "format": "double", | 
| -                    "type": "number" | 
| +                "iap": { | 
| +                    "$ref": "IdentityAwareProxy" | 
| }, | 
| -                "cpu": { | 
| -                    "description": "Number of CPU cores needed.", | 
| -                    "format": "double", | 
| -                    "type": "number" | 
| -                } | 
| -            }, | 
| -            "type": "object" | 
| -        }, | 
| -        "Volume": { | 
| -            "description": "Volumes mounted within the app container. Only applicable for VM runtimes.", | 
| -            "id": "Volume", | 
| -            "properties": { | 
| -                "sizeGb": { | 
| -                    "description": "Volume size in gigabytes.", | 
| -                    "format": "double", | 
| -                    "type": "number" | 
| +                "authDomain": { | 
| +                    "description": "Google Apps authentication domain that controls which users can access this application.Defaults to open access for any Google Account.", | 
| +                    "type": "string" | 
| }, | 
| -                "name": { | 
| -                    "description": "Unique name for the volume.", | 
| +                "codeBucket": { | 
| +                    "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", | 
| "type": "string" | 
| }, | 
| -                "volumeType": { | 
| -                    "description": "Underlying volume type, e.g. 'tmpfs'.", | 
| +                "defaultBucket": { | 
| +                    "description": "Google Cloud Storage bucket that can be used by this application to store content.@OutputOnly", | 
| "type": "string" | 
| -                } | 
| -            }, | 
| -            "type": "object" | 
| -        }, | 
| -        "ListInstancesResponse": { | 
| -            "description": "Response message for Instances.ListInstances.", | 
| -            "id": "ListInstancesResponse", | 
| -            "properties": { | 
| -                "instances": { | 
| -                    "description": "The instances belonging to the requested version.", | 
| +                }, | 
| +                "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": "Instance" | 
| +                        "$ref": "UrlDispatchRule" | 
| }, | 
| "type": "array" | 
| }, | 
| -                "nextPageToken": { | 
| -                    "description": "Continuation token for fetching the next page of results.", | 
| +                "gcrDomain": { | 
| +                    "description": "The Google Container Registry domain used for storing managed build docker images for this application.", | 
| +                    "type": "string" | 
| +                }, | 
| +                "name": { | 
| +                    "description": "Full path to the Application resource in the API. Example: apps/myapp.@OutputOnly", | 
| +                    "type": "string" | 
| +                }, | 
| +                "id": { | 
| +                    "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.", | 
| +                    "type": "string" | 
| +                }, | 
| +                "defaultCookieExpiration": { | 
| +                    "description": "Cookie expiration policy for this application.", | 
| +                    "format": "google-duration", | 
| +                    "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" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "OperationMetadataV1Alpha": { | 
| -            "description": "Metadata for the given google.longrunning.Operation.", | 
| -            "id": "OperationMetadataV1Alpha", | 
| +        "Instance": { | 
| +            "description": "An Instance resource is the computing unit that App Engine uses to automatically scale an application.", | 
| +            "id": "Instance", | 
| "properties": { | 
| -                "warning": { | 
| -                    "description": "Durable messages that persist on every operation poll. @OutputOnly", | 
| -                    "items": { | 
| -                        "type": "string" | 
| -                    }, | 
| -                    "type": "array" | 
| +                "averageLatency": { | 
| +                    "description": "Average latency (ms) over the last minute.@OutputOnly", | 
| +                    "format": "int32", | 
| +                    "type": "integer" | 
| }, | 
| -                "insertTime": { | 
| -                    "description": "Time that this operation was created.@OutputOnly", | 
| -                    "format": "google-datetime", | 
| +                "id": { | 
| +                    "description": "Relative name of the instance within the version. Example: instance-1.@OutputOnly", | 
| "type": "string" | 
| }, | 
| -                "user": { | 
| -                    "description": "User who requested this operation.@OutputOnly", | 
| +                "vmIp": { | 
| +                    "description": "The IP address of this instance. Only applicable for instances in App Engine flexible environment.@OutputOnly", | 
| "type": "string" | 
| }, | 
| -                "target": { | 
| -                    "description": "Name of the resource that this operation is acting on. Example: apps/myapp/services/default.@OutputOnly", | 
| +                "memoryUsage": { | 
| +                    "description": "Total memory in use (bytes).@OutputOnly", | 
| +                    "format": "int64", | 
| "type": "string" | 
| }, | 
| -                "ephemeralMessage": { | 
| -                    "description": "Ephemeral message that may change every time the operation is polled. @OutputOnly", | 
| +                "vmStatus": { | 
| +                    "description": "Status of the virtual machine where this instance lives. Only applicable for instances in App Engine flexible environment.@OutputOnly", | 
| "type": "string" | 
| }, | 
| -                "method": { | 
| -                    "description": "API method that initiated this operation. Example: google.appengine.v1alpha.Versions.CreateVersion.@OutputOnly", | 
| +                "errors": { | 
| +                    "description": "Number of errors since this instance was started.@OutputOnly", | 
| +                    "format": "int32", | 
| +                    "type": "integer" | 
| +                }, | 
| +                "availability": { | 
| +                    "description": "Availability of the instance.@OutputOnly", | 
| +                    "enum": [ | 
| +                        "UNSPECIFIED", | 
| +                        "RESIDENT", | 
| +                        "DYNAMIC" | 
| +                    ], | 
| +                    "enumDescriptions": [ | 
| +                        "", | 
| +                        "", | 
| +                        "" | 
| +                    ], | 
| "type": "string" | 
| }, | 
| -                "endTime": { | 
| -                    "description": "Time that this operation completed.@OutputOnly", | 
| +                "startTime": { | 
| +                    "description": "Time that this instance was started.@OutputOnly", | 
| "format": "google-datetime", | 
| "type": "string" | 
| -                } | 
| -            }, | 
| -            "type": "object" | 
| -        }, | 
| -        "UrlDispatchRule": { | 
| -            "description": "Rules to match an HTTP request and dispatch that request to a service.", | 
| -            "id": "UrlDispatchRule", | 
| -            "properties": { | 
| -                "service": { | 
| -                    "description": "Resource ID of a service in this application that should serve the matched request. The service must already exist. Example: default.", | 
| +                }, | 
| +                "vmDebugEnabled": { | 
| +                    "description": "Whether this instance is in debug mode. Only applicable for instances in App Engine flexible environment.@OutputOnly", | 
| +                    "type": "boolean" | 
| +                }, | 
| +                "requests": { | 
| +                    "description": "Number of requests since this instance was started.@OutputOnly", | 
| +                    "format": "int32", | 
| +                    "type": "integer" | 
| +                }, | 
| +                "appEngineRelease": { | 
| +                    "description": "App Engine release this instance is running on.@OutputOnly", | 
| +                    "type": "string" | 
| +                }, | 
| +                "vmName": { | 
| +                    "description": "Name of the virtual machine where this instance lives. Only applicable for instances in App Engine flexible environment.@OutputOnly", | 
| "type": "string" | 
| }, | 
| -                "domain": { | 
| -                    "description": "Domain name to match against. The wildcard \"*\" is supported if specified before a period: \"*.\".Defaults to matching all domains: \"*\".", | 
| +                "qps": { | 
| +                    "description": "Average queries per second (QPS) over the last minute.@OutputOnly", | 
| +                    "format": "float", | 
| +                    "type": "number" | 
| +                }, | 
| +                "vmId": { | 
| +                    "description": "Virtual machine ID of this instance. Only applicable for instances in App Engine flexible environment.@OutputOnly", | 
| "type": "string" | 
| }, | 
| -                "path": { | 
| -                    "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.", | 
| +                "vmZoneName": { | 
| +                    "description": "Zone where the virtual machine is located. Only applicable for instances in App Engine flexible environment.@OutputOnly", | 
| "type": "string" | 
| -                } | 
| -            }, | 
| -            "type": "object" | 
| -        }, | 
| -        "ListVersionsResponse": { | 
| -            "description": "Response message for Versions.ListVersions.", | 
| -            "id": "ListVersionsResponse", | 
| -            "properties": { | 
| -                "versions": { | 
| -                    "description": "The versions belonging to the requested service.", | 
| -                    "items": { | 
| -                        "$ref": "Version" | 
| -                    }, | 
| -                    "type": "array" | 
| }, | 
| -                "nextPageToken": { | 
| -                    "description": "Continuation token for fetching the next page of results.", | 
| +                "name": { | 
| +                    "description": "Full path to the Instance resource in the API. Example: apps/myapp/services/default/versions/v1/instances/instance-1.@OutputOnly", | 
| "type": "string" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "ApiEndpointHandler": { | 
| -            "description": "Uses Google Cloud Endpoints to handle requests.", | 
| -            "id": "ApiEndpointHandler", | 
| +        "LivenessCheck": { | 
| +            "description": "Health checking configuration for VM instances. Unhealthy instances are killed and replaced with new instances.", | 
| +            "id": "LivenessCheck", | 
| "properties": { | 
| -                "scriptPath": { | 
| -                    "description": "Path to the script from the application root directory.", | 
| +                "checkInterval": { | 
| +                    "description": "Interval between health checks.", | 
| +                    "format": "google-duration", | 
| "type": "string" | 
| -                } | 
| -            }, | 
| -            "type": "object" | 
| -        }, | 
| -        "AutomaticScaling": { | 
| -            "description": "Automatic scaling is based on request rate, response latencies, and other application metrics.", | 
| -            "id": "AutomaticScaling", | 
| -            "properties": { | 
| -                "diskUtilization": { | 
| -                    "$ref": "DiskUtilization", | 
| -                    "description": "Target scaling by disk usage." | 
| }, | 
| -                "minPendingLatency": { | 
| -                    "description": "Minimum amount of time a request should wait in the pending queue before starting a new instance to handle it.", | 
| +                "timeout": { | 
| +                    "description": "Time before the check is considered failed.", | 
| "format": "google-duration", | 
| "type": "string" | 
| }, | 
| -                "requestUtilization": { | 
| -                    "$ref": "RequestUtilization", | 
| -                    "description": "Target scaling by request utilization." | 
| -                }, | 
| -                "maxIdleInstances": { | 
| -                    "description": "Maximum number of idle instances that should be maintained for this version.", | 
| -                    "format": "int32", | 
| -                    "type": "integer" | 
| -                }, | 
| -                "minIdleInstances": { | 
| -                    "description": "Minimum number of idle instances that should be maintained for this version. Only applicable for the default version of a service.", | 
| -                    "format": "int32", | 
| -                    "type": "integer" | 
| -                }, | 
| -                "maxTotalInstances": { | 
| -                    "description": "Maximum number of instances that should be started to handle requests.", | 
| -                    "format": "int32", | 
| -                    "type": "integer" | 
| -                }, | 
| -                "minTotalInstances": { | 
| -                    "description": "Minimum number of instances that should be maintained for this version.", | 
| -                    "format": "int32", | 
| +                "failureThreshold": { | 
| +                    "description": "Number of consecutive failed checks required before considering the VM unhealthy.", | 
| +                    "format": "uint32", | 
| "type": "integer" | 
| }, | 
| -                "networkUtilization": { | 
| -                    "$ref": "NetworkUtilization", | 
| -                    "description": "Target scaling by network usage." | 
| -                }, | 
| -                "coolDownPeriod": { | 
| -                    "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.", | 
| +                "initialDelay": { | 
| +                    "description": "The initial delay before starting to execute the checks.", | 
| "format": "google-duration", | 
| "type": "string" | 
| }, | 
| -                "maxConcurrentRequests": { | 
| -                    "description": "Number of concurrent requests an automatic scaling instance can accept before the scheduler spawns a new instance.Defaults to a runtime-specific value.", | 
| -                    "format": "int32", | 
| -                    "type": "integer" | 
| +                "path": { | 
| +                    "description": "The request path.", | 
| +                    "type": "string" | 
| }, | 
| -                "maxPendingLatency": { | 
| -                    "description": "Maximum amount of time that a request should wait in the pending queue before starting a new instance to handle it.", | 
| -                    "format": "google-duration", | 
| +                "host": { | 
| +                    "description": "Host header to send when performing a HTTP Liveness check. Example: \"myapp.appspot.com\"", | 
| "type": "string" | 
| }, | 
| -                "cpuUtilization": { | 
| -                    "$ref": "CpuUtilization", | 
| -                    "description": "Target scaling by CPU usage." | 
| +                "successThreshold": { | 
| +                    "description": "Number of consecutive successful checks required before considering the VM healthy.", | 
| +                    "format": "uint32", | 
| +                    "type": "integer" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "ZipInfo": { | 
| -            "description": "The zip file information for a zip deployment.", | 
| -            "id": "ZipInfo", | 
| +        "NetworkUtilization": { | 
| +            "description": "Target scaling by network usage. Only applicable for VM runtimes.", | 
| +            "id": "NetworkUtilization", | 
| "properties": { | 
| -                "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/<bucket>/<object>'.", | 
| -                    "type": "string" | 
| +                "targetSentBytesPerSecond": { | 
| +                    "description": "Target bytes sent per second.", | 
| +                    "format": "int32", | 
| +                    "type": "integer" | 
| }, | 
| -                "filesCount": { | 
| -                    "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.", | 
| +                "targetReceivedBytesPerSecond": { | 
| +                    "description": "Target bytes received per second.", | 
| +                    "format": "int32", | 
| +                    "type": "integer" | 
| +                }, | 
| +                "targetSentPacketsPerSecond": { | 
| +                    "description": "Target packets sent per second.", | 
| +                    "format": "int32", | 
| +                    "type": "integer" | 
| +                }, | 
| +                "targetReceivedPacketsPerSecond": { | 
| +                    "description": "Target packets received per second.", | 
| "format": "int32", | 
| "type": "integer" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "Library": { | 
| -            "description": "Third-party Python runtime library that is required by the application.", | 
| -            "id": "Library", | 
| +        "Location": { | 
| +            "description": "A resource that represents Google Cloud Platform location.", | 
| +            "id": "Location", | 
| "properties": { | 
| +                "labels": { | 
| +                    "additionalProperties": { | 
| +                        "type": "string" | 
| +                    }, | 
| +                    "description": "Cross-service attributes for the location. For example\n{\"cloud.googleapis.com/region\": \"us-east1\"}\n", | 
| +                    "type": "object" | 
| +                }, | 
| "name": { | 
| -                    "description": "Name of the library. Example: \"django\".", | 
| +                    "description": "Resource name for the location, which may vary between implementations. For example: \"projects/example-project/locations/us-east1\"", | 
| "type": "string" | 
| }, | 
| -                "version": { | 
| -                    "description": "Version of the library to select, or \"latest\".", | 
| -                    "type": "string" | 
| -                } | 
| -            }, | 
| -            "type": "object" | 
| -        }, | 
| -        "ListLocationsResponse": { | 
| -            "description": "The response message for Locations.ListLocations.", | 
| -            "id": "ListLocationsResponse", | 
| -            "properties": { | 
| -                "nextPageToken": { | 
| -                    "description": "The standard List next-page token.", | 
| +                "locationId": { | 
| +                    "description": "The canonical id for this location. For example: \"us-east1\".", | 
| "type": "string" | 
| }, | 
| -                "locations": { | 
| -                    "description": "A list of locations that matches the specified filter in the request.", | 
| -                    "items": { | 
| -                        "$ref": "Location" | 
| +                "metadata": { | 
| +                    "additionalProperties": { | 
| +                        "description": "Properties of the object. Contains field @type with type URL.", | 
| +                        "type": "any" | 
| }, | 
| -                    "type": "array" | 
| +                    "description": "Service-specific metadata. For example the available capacity at the given location.", | 
| +                    "type": "object" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "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.", | 
| -            "id": "ContainerInfo", | 
| +        "HealthCheck": { | 
| +            "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.", | 
| +            "id": "HealthCheck", | 
| "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\"", | 
| +                "host": { | 
| +                    "description": "Host header to send when performing an HTTP health check. Example: \"myapp.appspot.com\"", | 
| +                    "type": "string" | 
| +                }, | 
| +                "healthyThreshold": { | 
| +                    "description": "Number of consecutive successful health checks required before receiving traffic.", | 
| +                    "format": "uint32", | 
| +                    "type": "integer" | 
| +                }, | 
| +                "restartThreshold": { | 
| +                    "description": "Number of consecutive failed health checks required before an instance is restarted.", | 
| +                    "format": "uint32", | 
| +                    "type": "integer" | 
| +                }, | 
| +                "checkInterval": { | 
| +                    "description": "Interval between health checks.", | 
| +                    "format": "google-duration", | 
| +                    "type": "string" | 
| +                }, | 
| +                "timeout": { | 
| +                    "description": "Time before the health check is considered failed.", | 
| +                    "format": "google-duration", | 
| "type": "string" | 
| +                }, | 
| +                "unhealthyThreshold": { | 
| +                    "description": "Number of consecutive failed health checks required before removing traffic.", | 
| +                    "format": "uint32", | 
| +                    "type": "integer" | 
| +                }, | 
| +                "disableHealthCheck": { | 
| +                    "description": "Whether to explicitly disable health checks for this instance.", | 
| +                    "type": "boolean" | 
| } | 
| }, | 
| "type": "object" | 
| }, | 
| -        "RequestUtilization": { | 
| -            "description": "Target scaling by request utilization. Only applicable for VM runtimes.", | 
| -            "id": "RequestUtilization", | 
| +        "ReadinessCheck": { | 
| +            "description": "Readiness checking configuration for VM instances. Unhealthy instances are removed from traffic rotation.", | 
| +            "id": "ReadinessCheck", | 
| "properties": { | 
| -                "targetRequestCountPerSecond": { | 
| -                    "description": "Target requests per second.", | 
| -                    "format": "int32", | 
| +                "timeout": { | 
| +                    "description": "Time before the check is considered failed.", | 
| +                    "format": "google-duration", | 
| +                    "type": "string" | 
| +                }, | 
| +                "failureThreshold": { | 
| +                    "description": "Number of consecutive failed checks required before removing traffic.", | 
| +                    "format": "uint32", | 
| "type": "integer" | 
| }, | 
| -                "targetConcurrentRequests": { | 
| -                    "description": "Target number of concurrent requests.", | 
| -                    "format": "int32", | 
| +                "appStartTimeout": { | 
| +                    "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.", | 
| +                    "format": "google-duration", | 
| +                    "type": "string" | 
| +                }, | 
| +                "path": { | 
| +                    "description": "The request path.", | 
| +                    "type": "string" | 
| +                }, | 
| +                "successThreshold": { | 
| +                    "description": "Number of consecutive successful checks required before receiving traffic.", | 
| +                    "format": "uint32", | 
| "type": "integer" | 
| +                }, | 
| +                "host": { | 
| +                    "description": "Host header to send when performing a HTTP Readiness check. Example: \"myapp.appspot.com\"", | 
| +                    "type": "string" | 
| +                }, | 
| +                "checkInterval": { | 
| +                    "description": "Interval between health checks.", | 
| +                    "format": "google-duration", | 
| +                    "type": "string" | 
| } | 
| }, | 
| "type": "object" | 
|  |